Appendix A 


Syndication Source Code 


import j ava . io . * ; 
import javax. servlet . *; 
import javax. servlet .http. *; 

import java.util .Vector; //most methods of Vector are synchronized 
import java.net.*; 

/** 

* Servlet to retrieve content from Publisher server 

* Takes 7-9 parameters: 
* 

* db, content Server, linkBase, SectionID, ArticlelD, PartID, mode, 
unit, number 

* 

* ©author Technology 

* ^author ActivedataX.com 

* Last changed 11/9/99 
V 

public class ContentNOWjs extends HttpServlet implements Constants 
{ 

private static int itemsToKeep = 100, minutesToLive = 10; // init() 
may set the values later 

private static long lastModif ied; 
private static Vector contents = new Vector (); 

private Sentinel sentinel = new Sentinel { itemsToKeep, minutesToLive) ; 
private static final ReadURL server URL = new ReadURLO; 

public void doGet {HttpServletRequest req, HttpServletResponse resp) 

throws Servlet Except ion, IOSxception 

£ 

String ContentID, details- 
boolean newContent = falser- 
Content cont; //needed for lookup 

Params params = new Params (req); //decipher the request 
String ContentID = params . contentServer //req. getParameter { "Server" ) 

+ "?db=" + params. db 

+ *&:SectionID= B + params . SectionID 

+ w &ArticleID=* + params .ArticlelD 

+ *&:PartID=* + params . PartID 

+ "&ln=* + params . linkBase 

+ "kmode^ + params. mode ; 
if- {params. unit != null) 

{ContentID = ContentID + "kunit^" + params. unit 
+ n &number=" + params . number ; 

} 

if (params . templateURL — null) { 
params . templateURL = 
"http: / /www. lehighvalleynow. com/rol/template4.asp ,, ; 
} 
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ContentID = ContentID + "&tpl= w + params . templateURL; 
// parameter tpl will be ignored by serverURL . getContent , used for 
internal ID only 

cont = lookup (ContentID) ; 
if (cont != null) 
detail = cont, detail ; 
else 
{ 

try 

{ System. out .print In (ContentID) ; 

detail = serverURL. getContent (ContentID) ; 

detail = convertTojs {detail, params) ; 

newContent = true; 
} catch {Exception ex) {detail = ex.toStringO ; 3 

} 

//PrintWriter out = resp.getWriter { ) ; // ServletOutputStream 
bombs with \u0018: CharConversionException 
//out. print (detail) ; 
//System. out .println (detail) ; 
OutputStream out = resp. getOutputStream( ) ; 
out. write (detail. getBytes ( ) ) ; 
System. out .println {detail) ; 
out . flush ( ) ; 
out . close { ) ; 

if (newContent) 
{ 

lastModified = System . currentTimeMillis ( ) ; 

cont = new Content {ContentID, detail, lastModified); 
contents . addElement { cont ) ; 
} 

} 

public long getLastModif ied (HttpServletRequest req) 
{ 

return lastModif ied/1000*1000; 

} 

private String convertTojs (String htmlText, Params params) { 
html Text = htmlText . replace { ' \r ' , ' ' ) ; 
htmlText = htmlText . replace { ' \n 1 , f 1 ) ; 
htmlText = swapSt rings {htmlText , "\\", backslash); 
htmlText = swapSt rings {htmlText , " \ ' " , apostrophe); 
htmlText = swapStrings (htmlText , »\«« , doubleQuote) ; 

if (params.ArticlelD.equalsrO*) ) { 

htmlText = JavaScript .openArticle( ) + makeJavascriptHrefs (htmlText, 
params) ; 
> 

return "document .write { \ " n + htmlText + " \ w ) ; " ; 

} 

// pre-pend JavaScript . expandHeader { ) here for use by all header 
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items . // 

//+ the above line is skipped mysteriously 
// specific full article, just print 
// parse out href=, get ArticlelD, replace with 
j avascr ipt : expandHeader (ArticlelD) 

private String makeJavascriptHrefs (String html Text, Params params){ 
//find n <a n , find "href= H , find n ArticleID= K , find '>' 
//replace href= with javascript: expandHeader (ArticlelD) 
int indexBeginA, indexHref, indexArticlelD, 

ArticlelDEndsAt , indexEndA, indexClosingA; 
String ArticlelD = null; 

String htmlTextLowercase = htmlText . toLowerCase { ) ; 
StringBuffer newHtml = new StringBuf f er { ) ; 
int indexStart = 0; 

indexBeginA = htmlTextLowercase. indexOf ( "<a B , indexStart) ; 
indexHref = htmlTextLowercase. indexOf { "href =" , indexBeginA + 2); 
indexArticlelD = htmlTextLowercase . indexOf ( "articleid= w , indexHref 
5) + 10; 

indexEndA = htmlTextLowercase . indexOf ( "> n , indexArticlelD); 
indexClosingA = htmlTextLowercase. indexOf ( "</a> " , indexEndA) + 4; 
while (indexBeginA >= 0 && indexBeginA < indexHref 
&& indexHref < indexArticlelD 
&& indexArticlelD < indexEndA 
indexEndA < indexClosingA) { 
ArticlelDEndsAt = htmlTextLowercase. indexOf ( , 
indexArticlelD) ; 

//ArticlelD = 1 a r + htmlTextLowercase. substring (indexArticlelD, 
ArticlelDEndsAt) ; 

ArticlelD = htmlTextLowercase. substring ( indexArticlelD, 
ArticlelDEndsAt) ; 

newHtml . append (htmlText . substring ( indexStart , 
indexHref ) ) . append ( ,r href = " ) ; 

newHtml . append ( n \ \ \ " javascript : openArticle ( \\\ ' tt + 
params . templateURL + B ? Sect ion ID=" 

+ params . Sect ionID + tt ScArticleID=" + ArticlelD + 
rt &PartID=2&db= M + params. db + w \ \\ • ) ; \ \ \ " " ) ; 

/ /newHtml . append ( " \\\ n java script : expandHeader ( * + ArticlelD + 
") ;\\\* n ) ; 

newHtml . append (htmlText . substring ( indexEndA, indexClosingA) ) ; / 
done with one anchor. 

//newHtml .append ( JavaScript .appendAr tic leMain (params . request URL, 
params. db, params . Sect ionID, ArticlelD) ); 

//new loop starts over 

indexStart = indexClosingA; 

indexBeginA = htmlTextLowercase . indexOf ( n < a " , indexStart); 
indexHref = htmlTextLowercase . indexOf ( "href = " , indexBeginA) ; 
indexArticlelD = htmlTextLowercase. indexOf { "articleid= B , 
indexHref + 5) + 10; 

indexEndA = htmlTextLowercase . indexOf ("> ff , indexArticlelD); 
indexClosingA = htmlTextLowercase . indexOf ( " </a> B , indexEndA) + 
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//else use old value to get the tail. 

} 

//newHtml. append (html Text. substring (indexClosingA) ) ; 
return newHtml . toString ( ) ; 

} 

Content lookup {String contentID) 
{ Content cont; 
int index = -1; 

for (int i=0; i<contents , size { ) ; ++i) 
{ 

cont = (Content) contents. element At (i) ; 
if {contentID. equals (cont . contentID) ) 
{ 

return (Content) contents . element At ( i } ; 

} 

} 

return null; 

} 

public void destroy {) 
{ 

sentinel .quit = true; 
contents = null; 

} 

class Content 
{ 

String contentID, detail; 
long timestamp; 

Content (String contentID, String detail, long timestamp) 
{ 

this .contentID = contentID; 
this. detail = detail; 

this. timestamp = timestamp/ 60 000 ; //converts millis to min 

} 

} 

/ * * 

* Monitors the content collection, trims and freshes. 
*/ 

private class Sentinel extends Thread 
{ 

int itemsToKeep; 
int minutesToLive ; 
boolean quit = false; 

Sentinel (int itemsToKeep, int minutesToLive) 
{ 

this . itemsToKeep = itemsToKeep; 
this .minutesToLive = minutesToLive; 
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setPr iori ty ( Thread . MINJPRIORITY ) ; 
start { ) ; 

} 

I * * 

* The only and single thread 
*/ 

public void run() 
{ 

int itemsToRemove; 

while { Iquit } // this keeps cleanup alive until servlet is 
destroyed. 

{ 

freshen ( ) ; 

if (contents. size () > itemsToKeep) 

trim ( ) ; 
//System. gc { ) ; 
try{ 

Thread. sleep (5000) ; 

}catch (InterruptedException ex) {} 
} 

} 

private void trim() 
{ 

int itemsToRemove = contents . size ( ) - itemsToKeep; 
int trimmed = 0; 

for (int i=0; i< itemsToRemove; ++i) 

{ 

contents . removeElementAt (i ) ; 

Thread.yieldf) ; 

trimmed++; 

} 

if (trimmed > 10) contents . trimToSize {) ; 


private void freshen () 
{ 

long currentTime = System. currentTimeMillis () /60000 ; 
Content cont; 

for (int i=0; i<contents . size ( ) ; 
{ 

cont = (Content) con t en t s. element At (i) ; 

if (cont .times tamp + minutesToLive < currentTime) 

{ 

contents . removeElementAt ( i ) ; 
Thread. yield O ; 

} 

} 
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public String getServletlnf o ( ) 
{ 

return "Retrieves content from PublishNOW server*; 

} 

public void init (ServletConf ig config) throws Servlet Except ion 
{ 

super. init {config) ; 

if ( getlnitParameter ("itemsToKeep") != null ) 
{ 

try{ 

this.itemsToKeep = 
Integer .parselnt (getlnitParameter ( " itemsToKeep" ) ) ; 

} 

catch (Number Format Except ion e) { 
this.itemsToKeep = 100; 

} 

} 

else this.itemsToKeep = 100; 

if ( getlnitParameter { "minutesToLive" ) 1 = null } 
{ 

try{ 

this .minutesToLive = 
Integer -parselnt (getlnitParameter {"minutesToLive") ) ; 

} 

catch (NumberFormatException e) { 
this. minutesToLive = 15; 

} 

} 

else this .minutesToLive = 15; 

} 

String swapStrings (String Text In, String OldString, String NewString) 
{ 

int OldStringStartAt; 

int OldStringLength = OldString. length () ; 
int NewStringLength = NewString . length {} ; 
String TempText = Text In; 

OldStringStartAt = indexOf I gnoreCase (TempText , OldString, 0) ; 
while (OldStringStartAt != -1) 
{ 

TempText - TempText . substring ( 0, OldStringStartAt) + 
NewString + TempText . substring (OldStringStartAt + 
OldStringLength) ; 

OldStringStartAt = indexOf IgnoreCase (TempText , 
OldString, 

OldStringStartAt + NewStringLength) ; 

) 

return TempText; 
} 

int indexOf IgnoreCase ( String TempText, String substring, 
int StartAt) 
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{ 

return TempText . toLowerCase ( } . indexOf ( substring . toLowerCase ( ) , 
Start At) ; 
} 


class ReadURL 
{ 

public String getContent {String SourceURL) throws Exception 

{ 

URL page; 

Buf feredReader in; 
int len; 

page = new URL ( SourceURL) ; 

in = new Buf feredReader (new InputStreamReader (page . openStream{ ) ) ) ; 

long time - System. cur rent TimeMi 11 is () ; 

CharArrayWriter chbuffer= new Char ArrayWr iter ( ) ; 

chart] cbuf = new char [1024]; 

while (den = in. read(cbuf , 0, 1024)) i= -1) 

{ 

chbuf fer. write (cbuf , 0, len}; 

} 

in. close ( ) ; 

time = (int) (System. currentTimeMil lis ( ) - time); 
return chbuf f er . toString { ) + "<etime " + time + n ms/>"; 

} 

} 

class JavaScript implements Constants { 
static String expandHeader ( ) { 

return "ocript language=\\\ M JavaScript \\\ ">f unction 
expandHeader (ArticlelD) " + 

"{ArticlelD. style. display = (ArticlelD. style .display == 
WVnoneWV')? \\\ n \\\ n : \\\ B none\\\ B }<\\/script> n ; 

} 

static String openArticle ( ) { 

return n <script language=\\\ tt JavaSc rip t\\\"> function 
openArticle (url) " + 

"{var kk = window. open (url , 
\ \\ 1 Regiononl ine\ \ \ ' , \ \ \ 1 resi zabl e=yes , menubar=yes , scrol lbars=yes , width 
640,height=400\\\ * ) ; }<\\/script> » ; 

} 

static String appendArticleMa in (String content Server, 

String db, String SectionID, String ArticlelD) { 
return n <div ID=\\\" - + ArticlelD + "\\\" 
style=\\\"di splay :none\\\ M >" 

+ n <script language=\\\" JavaScript \\\ n w 

+ ,, src=\\\ nn + content Server //req.getParameter ( "Server" ) 
+ "?db= n + db 
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+ n &SectionID= B + SectionID 
+ "&ArticleID=* + Artie lelD.substring(l) 
+ n ScPartID=2\\\ , '><\\/script> tt 
+ endDiv; 

} 

} 

interface Constants { 

static final String apostrophe = n \\\ in ; //used in document .writ e {} 
static final String doubleQuote = n \\\" n ; //used in document .writ e {) 
static final String backslash = "\\\\ n ; //used in document .write 

0 

static final String beginScript = ,l <script language=\" javascript \ n > n ; 
static final String endScript = B <\\/script> n ; 
//static final String beginDiv = "<div 
static final String endDiv = n </div>"; 
static final String newline = n \r\n tt ; 

} 


A-8 


Appendix B 


package com . rnci , products . PublishNow; 

import j avax. servlet . * ; 
in$>or t j avax . s ervlet . ht tp - * ; 
import java.i©.*;- 
import java.util.*; 
i»5>©rt j ava . sql . * ; 
import java.net.*; 

in$>ort ccia. rnci. products. DataModules. ePress; 

import com. rnci .products . BataModules .HttpServletDb; - 

public class j Syndicate extends HttpServletDb { 

private static String controlDb * rol control n ; 
private static String controlServer - "stoudt"; 
private static String defaultURL « 

"http ; // j syndicate . rnci . com/ servlet /com. rnci . products . PublishNow. j Content" - 
private static String defaultServer = "stoudt"; 
private static String defaultDb = "epublish"; 
private static String default Sec tionlB ~ "bnews n ; 

private static String default Document URL = "http://www.lehighvalleynow.com/rol/template4.asp"; 

private static int itemsToKeep - 200, minutesToLive = 3; //may be set by initO later- 
private static long lastModif ied; Y y lttLt " later 
private static Vector contents » new Vector (); 

private Sentinel sentinel = new Sentinel (itemsToKeep, minutesToLive) ; 

public void init(ServletConfig config) throws ServletException { 
super. anit (config) ; 

if (getlnit Parameter ("itemsToKeep") !- null) { 
try { 

this.itemsToKeep = Integer .parselnt { get Init Parameter ( "itemsToKeep") ) ; 

catch (Number FormatException e) { 
this.itemsToKeep ~ 100; 

} 

} 

else this.itemsToKeep = 100; 

if {getInitParameter("iainutesToLive w } != mill) { 
try { 

^ this .minutesToLive - Integer.parselnt {getlnitParameter £ "minutesToLive") ) ; 

catch (WumberFormatException e) { 
this. minutesToLive - 5; 

} 

} 

else this. minutesToLive = 5; 

public void destroy () { 
sentinel, quit - true; 
contents ~ mill; 

} 

//Process the HTTP Get request 
iS^ctp^ HttpServletResponse res) tlurows ServletException, 

uni^ol^ SeCti ° nID ' *' template^, refererURl, documents, redirects, 

int position, ArticlelD, PartID, mode, number; 
boolean newContent * false, overrideDef aults = true; 
Content cont/ 
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refererURI, = req.getHeader ("REFERER") ; 

// default is to use URL params 

overRide = req . get Parameter ( "overrideDef aults " ) ; 

if {overRide »- mill) { 

^ if (overRide. startsWith( ff f ").) overrideDef aults = false; 
//Document URL 

document URL = req. getParameter ( "document URL" ) ; 


, else { 

. //if (unit.lengthO < 3) unit = "<p>"; 
position = unit.lastlndexOf ( ,, / "); 
+ 1)-" iP ° Sition >ss 0) Unit * (overrideDef aults)? unit, substring {0, position): unit, substring (position 
}' 

//The number of teaser delimiters to count 
String numbers = req. getParameter ( "number" ) ; 
if {numbers null) numbers - " 4 " ; 
else { 

position - numbers. last IndexOf( n , "} ; 

if {position >=* 0) numbers = {overrideDef aults) ? numbers, substring {0, position)* 
numbers, substring (position +1); " 
} 

try { number = Integer, parse In t (numbers) ; } catch (Exception e) { number - 4; } 
Connection cnn = mill; 

contentID : newWindow + + server + \ - + db + " + SectionID + - + ArticlelD + », » + mode + 
n , n + unit + n f n + number + n + tempi at eURL; 

String validated = validateRequest (templateURL, documentURL, refererURL, db Sectioning 
if (validated, equals ("R") ) { " 

if {documentURL.indexOf ("?") 1= -I) { 

redirectURL = documentURL -f " &redirected=yes"; 

} else { 

redirectURL = documentURL + "?redirected-yes n ; 
^ HTMLtext = n location. href = \ nn + redirectURL + n \"; 
else if {validated. equals { "E") ) { 
Please^y^gain^ network error occurred in connecting to the database. 

} 

else If (validated. equals ("N") } { 
requesS!</B>"); ^ CUineilt * write < r <BR><B>This web site is not authorized to display the content 
} 

else { 

cont - lookup (contentID); 
if (cont null) { 
' HTMLtext = cont. detail ; 
} else { 
newContent = true; 


if ( (SectionID != null) && (db !- mill) s& (server null)) { 
try { 

cnn - dataConnMan.getConnecti on (server, db) ; 
ePress thisOne - new ePress (cnn) ; 

thisOne. setLink (templateURL); 
thisOne. setDb (db) ; 
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if {(unit null) (number > 0) ) { //getTeaser 

HTMLtext = thisOne.getTeasers (SectianID, ArticlelD, PartID / mode / unit,nVEEaber) ; 

} 

else { , //getContent 

HTMLtext - thisOne. getContent {SectionID, ArticlelD, PartID, mode) ; 

} 

HTMLtext = swaps t rings (HTMLtext, "&dfc=\ rt & server =" + server -f w & tempi at eURL= w + 
URLEncoder. encode (templateURL) + n &db=") ; 

if (newWindow. toLowerCase().startsWith("y n )) { // add the n target=_blank w to article Hrefs 
HTMLtext = makeArticleHref 3 (HTMLtext) ; 

} 

dataConnMan. f reeConnecti on ( server , db, cnn) ; 

} 

catch (Exception e) { 

HTMLtext = "<! Error connecting to database: " + e.toString{) + " — " + server + n > n ; 

} else { 

HTMLtext - w <! The SectionID, server, and db parameters are required, > w ; 

HTMLtext - convertTojs (HTMLtext, documentURL, ref ererURL) ; 

} 


if (documentURL == rail 7 ) documentURL = defaul t Document URL / 

//Should part 1 links bring up a new browser window? 
newWindow - req. getParameter ("newWindow") ; 
if (newWindow == null) newWindow = "no"; 
position - newWindow. 1 a stlndexGf (","); 

if (position >^= 0) newWindow = (overrideDefaults) ? newWindow. substring (0, position): 
newWindow. substring {position + 1); 

//The Requested SectionID 
•SectionID = req. getParameter ("SectionID") ; 
if. (SectionID == null) SectionID - default SectionID; 
position - SectionID. 1 as t IndexOf M ) ; 

if (position >= 0) SectionID « (overrideDefaults)? SectionID. substring^, position): 
SectionID. substring (position -f 1) ; 

//The Requested ArticlelD (0 for most recent article) 
- String ArticlelDs = req. getParameter ("ArticlelD") ; 
if (ArticlelDs mill) ArticlelDs = n 0 n ; 
position = ArticleID3.1astIndexOf ( n , w ) ; 
if (position >= 0) { 

if (overrideDefaults) ArticlelDs = ArticlelDs. substring (0, position); 

else ArticlelDs - ArticlelDs . substring (position + 1) ; 

try { ArticlelD = Integer .parselnt (ArticlelDs) ; } catch {Exception e) { ArticlelD = 0; } 

//The Requested Part (1 for title, 2 for main content) 
String PartlDs * req* getParameter ("PartID") ; 
if (PartlDs = null) PartlDs ^ *!**; 
position ~ PartlDs. 1 as tlndexOf ( w , ") ; 
if (position >- 0) { 

if (overrideDefaults) PartlDs - Par tIDs. subs t ring (0, position); 
. " else PartlDs = PartlDs. substring (position +1); 

try { PartID = Int eger. pars el nt (PartlDs) ; } catch (Exception e) { PartID « 2; } 
//Database Server 

server = req. get Parameter ("server*) ; 

if (server =■= null) server = def auitServer; 

position - server. last IndexOf w ) ; 

if (position >= 0) server = (overrideDefaults)? server, substring (0, position): 
server. substring (position +1); 
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//PublishN'ow Database 
db = req*getParameter (*db rt ) ; 
if (db = null) db = def aultDfo; 
position - db.lastlndexOf ( n r n ) ; 

if (position >= 0} db = (overrideDefaults) ? db. substrings, position): db. substring (position + 1) ; 
//Forward Link Template URL 

templateURL - req.getParameter { n tempi at eURL") ; 

if {templateURL == mill) templateURL = document URL; //if no templateURL is supplied, set 
templateURL equal to the current document 
position - tempi ateURL. las tlndexOf ( M , w ) ; 

if (position >= 0) templateURL (overrideDef aults) ? templateURL. substring (0, position): 
templateURL. substring (position + 1); 

//try { templateURL = URLDecoder. decode (templateURL) ; } 
//catch (Exception e) { } 

if (templateURL. indexOf ("SectionlD^") -1) { //if article detail page is same as part 1 links 
page 

templateURL = templateURL. substring (0 / documentURL.indexOf("SectionID=") - 1); 


//The iCount Parameter in ePress.java 
String modes = req. get Parameter ("mode") ; 
if (modes == null) modes = "Im- 
position = modes. lastlndexOf (","}; 
if (position >= 0) { 

if (overrideDef aults) modes = modes, substring (0 7 position); 

else modes = modes, substring (position + 1); 

} 

try { mode = Integer .parselnt (modes) ; } catch {Exception e) { mode = 1; } 

//The delimiting string for Teaser requests 
unit - req. get Parameter ("unit") ; 
if (unit == null) { } 


} 

Print-Writer out = res -getWriter Q ; 
res . setContentType ( "text /html " ) ; 

^S^^EST 0 ^"'^^"'' //only seen, to effect im a ges 

if ( newcont ent ) { 

lastModified = System. currentTimeMillis () ; 
j cont = new Content (content ID, HTMLtext, lastModified); 

contents. addElement (cont) ; 

} 

sfS^ectfonLrf dateRegUest < St ^ templateURL, String doc^entURL, String refererURL, string db, 
//returns «n% or "B" (connection error) 

String documentHOST = — , SQL — — , refererHOST « retchar="N"; 
1% do^n^Sr ! T r * fererIi0ST « parseHostFromURL(refererURL); 

U (do™tU^ l: ^ f - P-seHo S tPromURL(documentURL); 

- AND^ti^^ J"! ^now,section_name . - + SectionID + 

AND datetlme!up < getdat^O ^a^ime down^ getdate1?« ^^-^ LIKE * documentHOST + 
Connection cnn = null; ~ 
try { 

cnn « dataConnMan. getConnection (control Server, controlDb) ; 
Statement stmt ~ cnn. creates ta tement (} ; 
ResultSet rst = stmt .ex e cut eQuery (SQL) ; 
retchar = "N"; 

while (rst. next ()) retchar = n Y"; 
rst. close () ; 
stmt. close () ; 


^ dataConnMan. f reeConnecti on (control Server, controlDb, cnn) ; 
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catch {Exception e) { 
ret char = "E" ; 

} 

} 

return ret char; 

} 

private String parseHostFromURl {String targetURL) { 

StringTokenizer tokenizer = new StringTokenizer (targetURL, V w ) ; 
int tokencount ~ tokenizer. count Tokens {} ; 
int i; 

String returnHost - " " ; 
xf (tokencount > 1) { 

for (i - 1; i < 3; i++) returnHost - tokenizer.nextToken() ; 
} else { 

returnHost - 

} 

return returnHost; 


private String makeArticleHref s (String HTMLtext) { 
int i; 

StringBuffer sb - new StringBuf f er () ; 

for (i = 0; i < HTMLtext .length () i++) { 

if { (HTMLtext. substring (i,i+l) .equals{"<") ) 
&& (HTMLtext. substring (i+1, i+2) .egualsIgnoreCase ("a") ) 
&& {HTMLtext. substring (i+3 f i+4) . equals ( "H") ) 
&£ (HTMLtext. substring {i+4, i+5) .equals ("r") ) ) { 
sb. append ("<a target=A"_blank\" ,r ) ; 

} else { 

sb< append (HTMLtext . charAt (i) } ; 

} 

} 

return sb. toString{ ) ; 


public long getLastModif ied (HttpServletReguest req) { 


return 1 astModified/ 1000*1 000; 
} . 

'private String convertTojs (String HTMLtext, String document URL, String refererURL) { 

HTMLtext = HTMLtext.replaceCNr'j 1 r ); 
HTMLtext = HTMLtext. replace ( » \n l , 1 *}/ 

try { 

HTMLtext « swapStrings (HTMLtext, "W'/WW"); 
HTMLtext = swapStrings (HTMLtext, "V a , *\\V ") ; 
HTMLtext « swapStrings (HTMLtext, "\ ww , n \\\ nn ) ; 

} 

catch (Exception e} { 

System, out .print In (e. getMessage { ) ) ; 

} ■ 

if (refererURL mill) { 

HTMLtext == n if (location. href .indexOf (\ ww + documentURL + w \ n > != -1} { document. write ( ,w + 
HTMLtext + nr ); } else { document, write ( ' <BR><B>This web site is not authorized to display the content 
requested.*:/^*}; } n ; 

} else { 

HTMLtext = n document. write (* n + HTMLtext +"');"; 

} 

return HTMLtext; 
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String swapStrings (String Textln, String OldString, String NewString) 
{ 

int OldStringStartAt; 

int OldStringLength = OldString. length {} ; 
int NewStringLength = NewString. length (} ; 
String TempText = Text In; 

OldStringStartAt = indexQf IgnoreCase (TempText, OldString, 0); 
while ( OldStringStartAt != -1) 
{ 

TempText =* TempText. substring ( 0, OldStringStartAt) + 

NewString + TempText. substring (OldStringStartAt + OldStringLength); 
OldStringStartAt - indexOf IgnoreCase (TempText, 
- OldString, 
OldStringStartAt + NewStringLength) ; 

} 

return TempText; 

} 

int indexOflgnoreCase (String TempText, String substring, 
int StartAt) 

{ 

return TempText . toLowerCase { ) , indexOf ( substring. toLowerCase ( ) , StartAt) ; 

} 

Content lookup (String contentID) { 
Content cont; 
int index - -1; 

for (int i=0; i<contents. size {) ; ++i) { 
cont = ( Con t ent ) cont ent s . el ementAt ( i ) ; 

if { content ID . equal s ( cont . cont ent ID ) ) return ( Content ) contents . el ementAt ( i ) ; 

} 

return null; 

} 

class Content { 

String contentID, detail; 
long time s tamp; 

Content (String contentID, String detail, long timestamp) { 
this. contentID - contentID; 
this -detail — detail; 

this.timestamp = timestamp/ 60000; //converts milliseconds to minutes 

} 

} 

private class Sentinel extends Thread { 
int itemsToKeep; 
int minute sToLive; 
boolean quit - false; 

Sentinel (int itemsToKeep, int minutesToLive) { 
. this. itemsToKeep « itemsToKeep; 

this. minutesToLive - minutesToLive; ' 

setPriority(Thread.MIN PRIORITY); 

start (); 

} 

public void run {) { 
int i terns ToRemove; 

while (tquit) { // this keeps cleanup alive until servlet is destroyed 
freshen < ) ; -* 
if (contents. size () > itemsToKeep) trim(); 
//System. gc() ; 

try i 

Thread. sleep (5000) ; 

1 

catch (InterruptedException ex) { } 

//System.out.println( w Sentinel ran at:* + System. currentTimeMillis {)) ; 
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private void trim() { 
. Ant iteinsToRemove ~ contents . size <) - itemsToKeep; 
int trimmed - 0; 

for {int i-0; i<itemsToRemove; ++i) { 
contents - remove El ementAt (i ) ; 

//System, out . println ( "Removed: " + contents . el ementAt ( i ) . toString ( ) ) 

Thread. yield {) ; 

trimmed++; 

} 

if (trimmed > 10} contents .trimToSize () ; 

} 

private void freshen () { 

long currentTime - System. currentTimeMillis {)/ 60000; 
Content cont; 

for (int i=0; i<contents.size{) ; ++i) { 
cont = ( Content } content s . el ementAt ( i ) ; 
if (cont.timestamp + minutesToLive < currentTime) { 
content s . removeEl ementAt ( i ) ; 

//System, out. print In ("Expired: " + cont. content I D) ; 
Thread . yield ( ) ; 

} 

} 

I 

} 


//Get Servlet information 
public String getServletlnfo () { 

return "Retrieves content from PublishNow 2.x databases."; 

} 
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Appendix C 


/** 

* Title: Active Data Syndicator - ADPExport Servlet 

* Description: Copyright (c) 2001 Active Data Exchange. All rights reserved. 

* Any use without the express written permission of the copyright 

* owner is unlawful. 

* All information contained in the file is confidential to Active Data Exchange 

* Copyright: Active Data Exchange 

* Company: Active Data Exchange 

* ©author John E. Wetzel 

* @ creation date 10 February 2001 

* @last revision date 13 June 2001 

* Aversion 3.01 
*/ 


package com . activeda tax . products . syndicator . export ; 

import j avax . servlet . * ; 

import j avax. servlet .http.*,* 

import j ava . i o . * ; 

import j ava . sql .Connection; 

import java.util .StringTokenizer; 

import java.util . Properties; 

import com. activeda tax. uti Is. adxTools; 

impor t j ava .net. URLEncoder ; 

import com. activeda tax. sql .HttpServletDb; 

public class ADPExport extends HttpServletDb { 
private static String sServer ; 
private static String sDbName; 
private static String sNoAuthMsg; 


private static final String C ONTENT_TY PE - "text/html" ; 
/**Initialize global variables*/ 

public void init (ServletConf ig config) throws ServletException { 
super .init (con fig) ; 

File f - new File ( "SyndicatorBG. properties " ) ; 
if ( !f . exists () ) { 

f = new File( tt I :/SyndicatorBG/ Syndica torBG. properties" ) ; 

> 

Properties dbProps = new Properties {) ; 
try { 

InputStream is = new FilelnputStream(f } ; 
dbProps . load (is); 

} 

catch (Exception e) { 

System. err. print In ("Can't read the properties file from ADPExport servlet. 
"Make sure Syndica tor BG. proper ties is in the CLASS PATH ") ; 
return 

} 

sServer = dbPr ops. getProperty ( * syndica tor. database. server ») ; 
sDbName = dbProps .getProperty < "syndicator .database. name" ) ; 
sNoAuthMsg = dbProps .getProperty { "syndicator . adp .noauthmsg" ) ; 

} 

/**Process the HTTP Get /Post request*/ 
public void doGet (HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException { 

String sServerRoot = adxTools. get ServerRoot (request) ; 

String sDocumentURL = " " ; 

String sTargetURL = " " ; 

String sOf f erContentSetlds = "0"; 

String sltemlds = "0"; 

String sFullNums = "0"; 

String sArcNums = n 0" ; 


long lOf ferContentSetld = 0; 
long lSerial = 0; 
long iSubld = 0; 
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long lltemld = 0 ; 


int nFullNum = 0; 
int nArcNum - 0; 

boolean bNewVfindow = false; 
boolean bShowDates = false; 

//Serial Number Parameter (required) 
try { 

iSerial = Long. par seLong (request . getParameter ( ■ j 3 serial" ) > ; 
} catch (Exception e) { 
ISerial = 0; 

} 

//Subscriber Id Parameter (required) 
try { 

lSubld = Long.parseLong (request .get Parameter ( ■ j3sub n ) ) ; 
} catch (Exception e) { 
lSubld = 0; 

} 

//Offer Content Set Id Parameter (required) 

sOf f erContentSetlds = request .getParameter ( "j3ocset rt ) ; 

if (sOff erContentSetlds == null) sOf ferContentSetlds = *0"r 

//Document URL Parameter (required) 
sDocumentURL = request . getParameter { " j 3durl " ) ; 
if (sDocumentURL =- null) sDocumentURL = 
sDocumentURL = 

ADPExporter . remove Par amsFromURL ( sDocumentURL, " j 3 serial, j 3 sub, j3ocset , j 3durl , j3itemid, j3fullnum, j3 
arcnum, j3turl, j3newwindow, j3showdates, j 3 rand" ) ; 

//Target URL for Archive Links Parameter (optional) 
sTargetURL = request .getParameter ( "j 3 turl 11 ) ; 

if (sTargetURL == null) sTargetURL = sDocumentURL; //defaults to the requesting document 

//Item Id Parameter per Content Set (optional) 
sltemlds = request . getParameter ( "jSitemid" ) ; 
if (sltemlds == null) sltemlds = ■0"; 

//Number of Full Articles to Display per Content Set Parameter (optional) 

sFullNums = request .getParameter ( tt j3fullnum ff ) ; 

if (sFullNums == null) sFullNums = "1"; //default to 1 

//Number of Article Archive Links to Display per Content Set Parameter (optional) 

sArcNums = request .getParameter ( " j3arcnum B ) ; 

if (sArcNums == null) sArcNums - "0"; //default to none 

//Popup new window when an archive link is clicked? True or False (optional) 
try { 

bNewWindow = (new Boolean (request . getParameter { " j 3newwindow* ) ) ) . booleanValue ( ) ,- 
} catch (Exception e) { 

bNewWindow = false; //default to false 

> 

//Show dates along with archive links? True or False (optional) 
try { 

bShowDates = (new Boolean (request .getParameter ( " j3showdates n ) ) ) .booleanValue ( ) ; 
} catch (Except ion e) { 

bShowDates = false; //default to false 

} 

response . setContentType (CONTENT_TYPE) ; 
PrintWriter out = response. getWriter () ; 

//Expecting these tokenizers to have the same number of tokens. 
StringTokenizer tokenizer = new StringTokenizer (sOf ferContentSetlds, ":") ; 
StringTokenizer tFull = new StringTokenizer (sFullNums, n :") ; 
StringTokenizer tArc - new StringTokenizer (sArcNums, * : M ) ; 
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StringTokenizer tltems = new StringTokenizer (sltemlds , " : w ) 7 
i f (tltems . countTokens ( ) ! = tokenizer . countTokens ( ) ) { 
sltemlds - "0"; 

for(int a=l;a<tokenizer .countTokens () ;a++) { 
sltemlds = sltemlds + W :0 W ; 

} 

tltems = new StringTokenizer (sltemlds, " : B ) ; 

> 


Connection cnn = dataConnMan . getConnect ion { this . sServer , this . sDbName) ; 

ADPExporter ADP = new ADPExporter ( cnn , sServerRoot, iSerial, ISubld, 0, 0, sDocumentURL, 
sTargetURL , 1 , 0 , bNewWindow, bShowDates , request . getHemoteAddr ( ) ) ; 

if (tokenizer. countTokens () > 1} { 

ADP. setAtomicQueryString {sltemlds, "&j3ocset= n + TJRLEncoder .encode (sOff er Con tent Set Ids) +- 
,, &j3arcnum=" + TJRLEncoder . encode { sArcNums ) + tt &:j3fullnum=* + URLEncoder - encode ( sFullNums) ) ; 
} 

int nTk = 0; 

while ( tokenizer . hasMoreTokens ( ) } { 
try { 

lOf ferContentSetld - Long. par seLong ( tokenizer. next Token{) ) ; 

try { nFullNum = Integer .parselnt (tFull .nextToken ()) ; } catch (Exception ex) { nFullNum 

1;} 

try { nArcNum = Integer .parselnt (tArc. nextToken ()) ; } catch (Exception ex) { nArcNum = 

0;} 

try { lltemld = Long. par seLong (tltems . nextToken ( )) ; } catch (Exception ex) { lltemld = 

0;} 

ADP. setOf ferContentSetld ( lOf ferContentSetld) ; 
ADP. setFullNum (nFullNum) ; 
ADP. setArcNum (nArcNum) ; 
ADP. setltemld (lltemld) ; 
ADP. setAtomicPosition (nTk) ; 

if (ADP.validateADPRequest () ) { 

out . print In (ADP . getADPContent ( ) ) ; 

out.println( "document .write ( '<P>' ) ; ") ; 
} else { 

out .println( "document. write {' " + this . sNoAuthMsg + "');"); 

} 

} catch (Exception e) { 

out .println { "document ,write( '< ! An error occurred while parsing offer content set 

ids. >' ) ; ") ; 

} 

nTk++; 

} 

dataConnMan . f reeConnection ( this . sServer , this . sDbName , cnn } ; 
ADP = null; 
out. flush ( ) ; 
out. close { ) ; 

} 

public void doPost (HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException { 
doGet (request, response) ; 

> 

/**Clean up resources*/ 
public void destroy () { 
} 
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/ * * 

* Title: Active Data Syndicator - ADPExporter Class 

* Description: Copyright (c) 2001 Active Data Exchange. All rights reserved. 

* Any use without the express written permission of the copyright 

* owner is unlawful. 

* All information contained in the file is confidential to Active Data Exchange 

* Copyright: Active Data Exchange 

* Company: Active Data Exchange 

* ^author John E. Wetzel 

* @date 10 February 2001 

* @last revision date 21 June 2001 

* @version 3.01 
*/ 

package com. act iveda tax .products . syndicator . export ; 

import com. act iveda tax. u tils .adxUKLParser; 
import java .util . StringTokenizer ; 
import j ava . net . Ma 1 f ormedURLException ; 
/ / import com . imaginary . lwp . Identifier; 

import com. act iveda tax .products . syndicator . content . OutputType; 

import java. io.OutputStr earn; 
import java.net .URLEncoder; 
import java. io. FileOutputStream; 
import j ava . io . IOException ; 
import java. util .List; 
import j ava . rmi . Remo teExcept ion ; 
import j ava. util. Iterator ; 
import java .util .Date; 
import java. util .Collect ion; 
import java. util .StringTokenizer; 
import java .util .Hashtable ; 
import java.sql.*; 

import java . text . SimpleDateFormat ; 
import javax.servlet .http.HttpServletResponse; 
import com. ac t iveda tax. u til s .DigraphEncrypt ; 
import com. act iveda tax. utils .adxTools; 

import gnu . regexp . * ; 
/* 

* This class is a helper class for the ADPExport servlet. 
*/ 

class ADPExporter { 

// class variables /objects 
private Hashtable hi terns ; 
private Hashtable hltemContent; 
private Connection cnn; 

private String sServerRoot, sDocumentURL, sTargetURL, sAtomicQueryString, sIPAddress, 
sltemTokens ; 

private long lSerial, iSubld, lOf f erContentSetld, lContentSetld, lltemld; 
private int nPos? 

private boolean bNewWindow, bShowDates; 
int nFullNum, nArcNum, nltemHashSize; 

ADPExporter {Connection pCnn, String psServerRoot, long plSerial, long plSubld, long plltemld, 
long plOfferContentSetld, String psDocumentURL, String psTargetURL, 
int pnFullNum, int pnArcNum, boolean pbNewWindow, boolean pbShowDates, 
String psIPAddress) { 

// init class variables /objects 

this.cnn = pCnn; 

this.lSerial = plSerial; 

this.lSubld = plSubld; 

this.lltemld = plltemld; 

this. sServerRoot = psServerRoot ; 

this. lOff erContentSetld = plOfferContentSetld; 

this.lContentSetld = this.lOf f erContentSetld; 

this . sDocumentURI* - psDocumentTJRI* ; 
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this .sTargetURL = psTargetURL; 
this .nFullNum = pnFullNum; 
th i s . nArcNum = pnAr cNum ; 
this .bNewWindow = pbNewWindow; 
this.bShowDates = pbShowDates; 
this .sIPAddress - psIPAddress; 
this . sAtomicQueryStr ing = " " ; 
this .sltemTokens = " " ; 
this.nPos = -1; 

} 

public void setFullNumfint pnFullNum) { 
this.nFullNum = pnFullNum; 

} 

public void set ArcNum ( int pnArcNum) { 
this. nArcNum = pnAr cNum ; 

} 

public void setltemldflong plltemld) { 
this.lltemld = plltemld; 

} 

public void setoff erContentSetld (long plOf ferContentSetld) { 
this. lOf ferContentSetld = plOf ferContentSetld; 

} 

public void setAtomicQuery String (String psltemlds. String psAtomicQueryString) { 
this . s At omicQuery String = psAtomicQueryString ; 
this . sltemTokens = psltemlds ; 

} 

public void setAtomicPosition (int pnPos) { 
this.nPos = pnPos; 

> 

I * * 

* This method will check to see if the web site making the content request is 

* authorized to receive the content. 
*/ 

public boolean validateADPRequest { ) { 
String sSQL = " " ; 

String sURL = parseHostFromURL ( this . sDocumentURL) ; 
boolean bAuthorized =s false; 
PreparedStatement stmt; 
ResultSet rs; 

//A non-subscriber is requesting the content. 

//The value in pOf ferContentSetld refers to the "content_set_id" column of the content„set 
table . 

if ((this.lSerial == -1) && (this.lSubld == -1)) { 
this . IContentSetld = this . lOf ferContentSetld ; 

sSQL = " SELECT DISTINCT url.url_id, url . crt_class FROM url, content_set * 
+ "WHERE content_set.content_set_id = ? tt 
+ "AND UPPER (url. url) LIKE ? ■ 

+ "AND url.url_id NOT IN (SELECT DISTINCT url_id FROM subscriber_url) B 
+ "AND url.site_id = content_set . site_id 

try { 

s tm t = cnn . pr epar e S tat emen t { s SQL > ; 
stmt . clear Parameters ( ) ; 
stmt. setLongd, this. IContentSetld) ; 
stmt.setString(2, "% M + sURL. toUpperCase ( ) + "%"); 
stmt . setMaxRows ( 1 ) ; 
rs = stmt . executeQuery ( ) ; 
while (rs .next () ) { 
bAuthorized = true; 

} 

rs. close ( } ; 
stmt . close ( ) ; 
} catch {Exception e) { 
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e .print StackTrace ( ) ; 


//A subscriber is requesting the content. 
} else { 

sSQL = " SELECT DISTINCT url.url„_id, url .crt„class FROM url, of f er_content_set, " 
+ "subscription_subdetails, subscriber, subscriber_url " 
+ "WHERE (of f er_content_set .of f er_content_set_id = ? " 
+ "AND subscription__subdetails.serial_no = ? " 
+ "AND subscriber .subs criber_id - ? n 
+ "AND subscriberjurl . subscriber_id = ? M 
+ "AND url. url like ?} n 

+ "AND of f er_content_set .of f er_id = subscription_subdetails . of f er_id " 
+ "AND subscription_subdetails.subscriber_id = subscriber .subs criber_id " 
+ "AND subscriber. subs cri be r_id = subscriberjurl . subscriber_id " 
+ "AND subscriber_url.url_id = url.url_id"; 

try { 

stmt = cnn. prepares tat ement (sSQL) ; 
stmt . clear Parameters { ) ; 

stmt . setLong (1, this . lOf f erContentSetld) ; 
stmt . setLong (2 , this . iSerial ) ; 
s tmt. setLong (3, this. iSubld} ; 
stmt. setLong (4, this. lSubld) ,- 

stmt.setString(5, + sURL. toUpperCase ( ) + "% n ); 
stmt . setMaxRows ( 1 ) ; 
rs = stmt . executeQuery {) ; 
while (rs.nextO ) { 
bAuthorized = true; 

} 

rs .close ( ) ; 
stmt. closet) ; 
} catch (Exception e) { 
e . pr intStackTrace ( ) ; 

} 

} 

return bAuthorized; 


* This method retrieves the requested content as defined by this classes' parameters. 
*/ 

private void getltemHashData {) { 

this.nltemHashSize = Math .abs (this .nFullNum) + Math.abs (this .nArcNum) ; 
this.hltems = new Ha sht able (this .nltemHashSize) ; 
this.hltemContent = new Hashtable {this .nit emHashSize) ; 
Prepa reds tat ement stmt; 
ResultSet rs; 

String sSQL = n " , sltemReview = "N w , sltemlds = 

String [ ] sTemp = {»» f " f »» / »» / *» f »'i ( »» ; »« i »i / i»}. 

long IThisItemId; 

int nAllowedArcKum ~ 0; 

int nFullCount = 0; 

int nResu It Count = 0; 


if ( ] ( (this. ISerial == -1) (this.lSubld == -!))){ //A subscriber has requested the 
content . 

//get the necessary content_set_id with an additional query 
sSQL = "SELECT of f er_content_set . content_set_id, subdetails_cs .archives , 
subdetails_cs.item_review ■ 

+ "FROM of fer_content_set, subdetails_cs " 
+ "WHERE subdetails_cs.serial_no = ? w 
+ "AND subdetails_cs.of fer_content_set_id = ? " 
+ "AND subdetails_cs . output_type_id = ? " 

+ "AND subdetails„cs.of fer_content_set_id = of fer_content_set.of f er_content_set_id" 

try { 

stmt = cnn. prepares tat emen t (sSQL) ; 

stmt . clearParameters ( ) ; 

stmt . setLong ( 1 , this . ISerial ) ; 
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stint .setl/ong (2 , this . lOf £ erContentSetld) ; 

stmt . setlnt ( 3 , OutputType . ADP ) ; 

stmt . setMaxRows ( 1 ) ; 

rs = stmt . executeQuery ( ) ; 

while {rs .next () ) { 

this .IContentSetld = r s . getLong ( 1 ) ; 

nAllowedArcNum = rs . getlnt (2) ; 

sltemReview = rs . getString (3) ; 

} 

rs . close ( ) ; 
stmt. close () ; 
} catch (Exception e) { 

System. err ,println( "An ERROR ocurred in ADPExporter ..."); 
e.printStackTrace ( } ; 
return ; 

} 

//make sure the subscriber hasn't tried to request more archives than allowed 
if (nAllowedArcNum < this .nit emHashSize) this.nltemHashSize = nAllowedArcNum; 

} 

if {sltemReview. equals { "V } ) { 

return; //will need to code a block here when item_review feature is added 

} 

String sCsId = "AND item_content_set .content_set_id = ? "; 
if ( this .iContentSetld ~- -1) sCsId = "AND item. item__id = ? rt ; 

//now get the content set items (not including the actual content column) 

sSQL. = "SELECT item. item_id, item. title, item. subtitle, item. author , item. byline, " 

+ "item.link_text f item.meta_data, item. comments, i tern. incti tie, item. las t_updated_on 

+ "FROM item, item_content_set tt 

+ "WHERE UPPER ( item. status ) != ? AND item.timeup <= ? " 
+ "AND item. timedown >= ? " 

+ "AND item. item_id = item_content„set . item_id " 
+ sCsId 

+ " ORDER BY item.timeup DESC u ; 

try { 

stmt = cnn.prepareStatement (sSQL) ; 
stmt . clear Parameters ( ) ; 
stmt . setString ( 1 , "D" ) ; 

stmt.setTimestamp(2,new Times tamp ( (new Date( ) ) .get Time () ) ) ; 
stmt. set Times tamp( 3, new Times tamp ( (new Date() } .getTime() ) ) ; 
if (this. IContentSetld > -1) 

stmt . setLong (4 , this . IContentSetld) ; 
else 

stmt . setLong (4 , this . lltemld) ; 
stmt. setMaxRows (this .nltemHashSize) ; 
rs = stmt. executeQuery ( ) ; 
while (rs .next {) ) { 

lThisItemld = rs . getLong ( 1 ) ; 
// System. out .print In ("FOUND ITEM ID: " + lThisItemld) ; 
if (this.nFullNum > nFullCount) { 

if (nFullCount > 0) sltemlds = sltemlds + 

sltemlds = sltemlds + String. valueOf (lThisItemld) ; 

nFullCount++; 

} 

sTempfO] = String. valueOf (lThisItemld) ; //item_id 
sTempfl] = rs. getString (2 ) ; //title 
sTemp[2J = rs. getString (3 ) ; //subtitle 
if(sTemp[2 3 == null) sTemp[2] = " • ; 
sTemp[3] = rs. getString (4) ; //author 
if(sTemp[3] == null) sTemp[3] = " * ; 
sTemp[4] ~ rs. getString (5) ; //byline 
if(sTemp[4] == null) sTemp{4] - ""; 
sTemp[5] = rs . getString ( 6) ; //linktext 
if(sTemp[5] == null) sTemp[5] = " " ; 
sTemp[6] - rs. getString (7) ; //metadata 
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if{sTemp[6] == null) sTemp[6] - " " ; 
sTemp[7] - rs .get String (8) ; //comments 
if(sTemp[7] == null) sTemp[7] = 9 " ; 
sTemp[8] ~ rs.getString (9) ; //inctitle 

sTemp[9] = rs .getTimestamp £10) . toString( ) ; //displaydate 

this. hi terns .put (String. valueOf (nResultCount) , sTemp. clone {) ) ; 
nResultCount++ ; 

} 

rs.close() ; 
stmt .closet ) ; 
} catch (Exception e) { 

System, err .print In { "An ERROR ocurred in ADPExporter ..."),- 
e.printStackTrace( } ; 

} 

//finally get nFullNum number of item "content" fields or a specific item 
if { (sltemlds. length ( ) > 0) | | (this . lltemld > 0)) { 

if (this -lltemld > 0) { //a specific item link was clicked on 
sSQL = "SELECT item_id, content FROM item WHERE item_id =" + 
String. valueOf (this .lltemld) ; 
} else { 

sSQL = w SELECT item_id, content FROM item WHERE item_id INC + sltemlds + n >\- 

} 

try { 

stmt = cnn. prepar eSt a t ement {s SQL) ; 
stmt .clearParameters ( ) ; 
rs = stmt .executeQuery {) ; 
while (rs .next () ) { 

this .hi temC on tent .put (new Long (rs.getLong (1) ) , rs .getString (2} ) ; 

} 

rs . close ( ) ; 
stmt . close ( ) ; 
} catch (Exception e) { 

System. err. print In ( "An ERROR ocurred in ADPExporter ..."); 
e .printStackTrace ( ) ; 

} 

} 

} 

public String getADPContent ( ) { 
getltemHashData () ; 

String sURL = { this . sTargetURL . indexOf ( " ? " ) == -1) ? "? n : 
String sNewWindow = < this .bNewWindow) ? " TARGET=\ M __new\ * " : ntt ; 
String sLink, sContent, sDisplayDate, sltemldParameter ; 
StringBuffer cb = new StringBuf f er ( " M ) ; //content buffer 
StringBuffer lb = new StringBuf fer <■") ; //link buffer 
String [ ] sTemp,- 

int nFull = this .hit emCon tent .size (} ; 
int nltems = this .hltems . size () ? 

boolean bNegativeArcNum = (this .nArcNum < 0); 

// 

j 3 serial , j 3 sub, j 3ocset , j 3durl , j 3 i temid , j 3 f ullnum, j 3 arcnum, j 3 turl , j 3newwindow, j 3showdates , j 3 rand 
if (this. sAtomicOuerySt ring. length { ) > 0) { 

sURL += n j3serial=" + URLEncoder .encode {String. valueOf (this. lSerial) ) + lt &j3sub= n + 
URLEncoder . encode (String .valueOf ( this . lSubld) ) + 

this . s At omicQuery String + w So3newwindow= n + 
URLEncoder . encode (String .valueOf (this .bNewWindow) ) + 

"&j3showdates=" + URLEncoder .encode { String. valueOf (this. bShowDates) ) ; 

} else { 

sURL += n j3serial= tt + URLEncoder . encode {String. valueOf {this . lSerial) ) + "&j3sub=" + 
URLEncoder. encode (String. valueOf (this .lSubld) } + 

n &j3ocset=" + URLEncoder .encode (String. valueOf (this. lOfferCont entSet Id) ) + "&j3arcmnn= 

+ 

URLEncoder .encode (St ring. valueOf (this. nArcNum) ) + "&j3newwindow= B + 
URLEncoder . encode { String . valueOf ( this . bNewWindow) ) + 


C-8 


n &j3showdates=" + ul<LEncoder .encode (String. valueOf (this. bShowDates) ) ; 

} 


for (int i=0; i<nltems; i++) { 

sTemp = (String! ]) this. hitems. get (String. valueOf (i) } ; 
sContent = (String) this.hltemC ontent. get (new Long (sTempfO] )) ; 
if (sContent != null) { 

sContent = replaceltemBinaryRef s (sContent) ; 

//sContent = adxTools . swapStrings (sContent, "\u00f 3\u00f 3 " , this . sServerRoot + 
n com. activeda tax. products . syndicator. export .ADPRetrieveltemBinaryTbinary^d^ ) ; 
} else { 

sContent = " " ; 

} 

sLink = (sTemp [5 ] .trim() .length () > 0) ? sTemp [ 5 } . tr im ( ) : sTemp [1] . trim( ) ; 

sDisplayDate = sTemp[9]; 

if (this.bShowDates |[ bNegativeArcNum) { 

sDisplayDate = sDisplayDate. substring (5, 7) + "/" + sDisplayDate. substring (8, 10) + 9 J 9 + 
sDisplayDate .substring (2 , 4) ; 

sLink += " ( * + sDisplayDate + ")"; 

} 


//sTemp[0] 


item_id 

Z/sTempEl] 


title 

//sTemp[2] 


subtitle 

//sTemp[3] 


author 

//sTemp[4] 


byline 

//sTemp[5] 


linktext 

/ / sTemp [ 6 ] 


metadata 

//sTemp[7] 


comments 

//sTemp[8} 


inctitle 

//sTemp[9 3 


displaydate 


sltemldParameter = sTemp[0]; //the current item_id 
if (this. sAtomicQueryString. length () > 0) { 

StringTokenizer tit ems = new StringTokenizer ( this . sltemTokens , n : " ) ; 
if(this.nPos == 0) { 

sltemldParameter = sTemp[0] ; 
tltems.nextToken ( > ; 
} else { 

sltemldParameter = tit ems .nextToken ( ) ; 

> 

int nq - 1; 

while (tl terns .ha sMoreTokens () ) { 
if(this.nPos == nq) { 

sltemldParameter += " : " + sTemp[03; 

t I terns .nextToken ( ) ; 
} else { 

sltemldParameter += " : * + tl terns. next Token{ ) ; 

} 

nq++ ; 

} 

} 

if (sContent. length O > 0) { 
cb. append (sContent + "<p>"); 
if {Math. abs (this. nArcNum) > 0) 

if ( ( ! this.bNewWindow) |j ( (this.bNewWindow) && (this.lltemld==0) ) ) lb. append (sLink + 

"<BR>") ; 

} else { 

if (Math. abs (this.nArcHum) > 0) 

if ((! this.bNewWindow) |[ ((this.bNewWindow) && (this . lltemld==0) ) ) lb . append (" <A ■ 
HREF=\" ff + this.sTargetURL + sURL + M &j3itemid=" + URLEncoder .encode (sltemldParameter) ,+ * V " + 
sNewWindow + ">* + sLink + "</A><BR> n ); 
} 

} // end for * 
return parseContent (cb. toString ( ) + n <p>» + Ib.toStringO + tt <P> B , * " ) ; 

> 

private String replaceltemBinaryRefs (String psContent) { 

StringBuffer sb = new StringBuffer (psContent . length ( ) + 300); 
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String sld; 
int nPos = 0; 

int nLoc = psContent . indexOf ( w \u00f 3 \u00f 3 " ) ; 
while (nLoc l~ -1) { 

sb. append (psContent . substring {nPos, nLoc) ) ; 

sld = adxTools . convertStringToHexString (DigraphEncrypt . encryptDiGraph ( this . sIPAddress 
"TFB" + psContent. subs tr ing{nLoc+2, nLoc+22) } .trim{) ) ; 

sb . append { thi s . sServerRoot + 
"com.activedatax.products.syndicator . export . ADPRetrieveItemBinary?binary_id-' 1 + sld} ; 

nPos = nLoc + 22; 

nLoc = psContent. indexOf ( n \u00f 3 \u0 Of 3" ,nPos) ; 

} 

sb. append (psContent . substring (nPos) ) ; 
return sb. toString ( ) ; 

} 

* 

* This method will remove specified querystring parameters from a supplied URL 

* and return the resulting URL 
* 

* Example: For the method parameters 

* psURL = n http:/ /www. mysite. com/page. asp?paraml=x&param2=y&param3=z" 

* psQueryStringParams = "par ami , param3 " 
* 

* The returned URL will be: 

* "http: / /www. mysite . com/page. asp?param2=y" 
*/ 

public static String removeParamsFromURL (String psURL, String psQueryStringParams} { 
/ /System. out . println (URL) ; 
String sTempURL = psURL; 

StringTokenizer tokenizer = new StringTokenizer (psQueryStringParams r ") ; 
adxURLParser myParser = new adxURLParser () ; 
try { 

while (tokenizer .hasMoreTokens () ) { 
myParser . setOriginalURL(sTempURL) ; 
myParser . setParamToRemove ( tokenizer .nextTok en { ) ) ; 
sTempURL = myParser .getRemovedParamURL () ; 

} 

} catch (Malf ormedURLException mue) { 
mue . printStackTrace ( ) ; 

//return an error string that will need to be handled by the calling method. 
sTempURL - "error"; 

} 

return sTempURL ; 


/ * * 

* This method will parse out and return the host /domain name from a supplied URL 
* 

* Example: For the URL : 

* psURL = "http:/ /www. mysite. com/page. asp ?paraml=x&param2=y&param3=z 1 ' 
* 

* The returned String will be: 

* "www. mysite. com" 
*/ 

public static String par seHostFromURL (String psURL) { 

StringTokenizer tokenizer = new StringTokenizer (psURL, "/"}; 
int tokencount = tokenizer .countTok ens () ; 
int i; 

String sReturnHost - " " ; 
try { 

if (tokencount > 1) { 

for (i = 1; i < 3; i++) sReturnHost = tokenizer .next Token () ; 
} else { 

sReturnHost = "error"; 

} 

} catch (Exception e) { 
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//return an error string that will need to be handled by the calling method. 
sReturnHost = "error"; 

} 

return sReturnHost; 

} 

public static int indexOf IgnoreCase (String sTempText, String sSubString, int nStartAt) { 
return sTempText . toLowerCase ( ) . indexOf ( s Substring . toLowerCase ( ) , nStartAt} ; 

} 

/* 

public static String swapStrings (String sTextln, String sOldString, String sNewStrmg) { 
int nOldStringStartAt; 

int nOldStringLength = sOldString. length {) ; 
int nNewStringLength = sNewString . length {) ; 
String sTempText = sTextln; 

nOldStringStartAt = indexOf IgnoreCase (sTempText, sOldString, 0) ; 
while {nOldStringStartAt != -1) { 

sTempText = sTempText . substring { 0, nOldStringStartAt) + sNewString + 
sTempText . substring (nOldStringStartAt + nOldStringLength); 

nOldStringStartAt = indexOf IgnoreCase (sTempText , sOldString, nOldStringStartAt + 
nNewStringLength) ; 
} 

return sTempText; 

} 

*/ 

public static String parseContent (String sContent, String sServerRoot) { 
String sClientScripts = K "; 

int nStartSearchAt = 0; 

int nScriptLoc = indexOf IgnoreCase (sContent , n <SCRIPT" , nStartSearchAt) ; 
if (nScriptLoc > -1) { //Check for client scripts and separate them from regular HTML 
try { 

int nEndScriptLoc ; 

int nArticleLength = sContent . length () ; 

StringBuffer sbArticle = new StringBuffer (nArticleLength + 1) ; 
StringBuffer sbScripts = new StringBuf f er ( ) ; 
while (nScriptLoc > -1) { 

nEndScriptLoc = indexOf IgnoreCase (sContent , ,r </SCRIPT> nScriptLoc) ; 

sbArticle . append ( sContent . substring (nStartSearchAt , nScriptLoc) ) ; 

sbScripts . append (sContent . substring ( { indexOf IgnoreCase { sContent , " > " , nScriptLoc) +1 ) , nEndScriptLoc ) 
); 

sbScripts . append ( ' \n ' ) ; 
sbScripts . append { ' \r ' ) ; 

/ /System. out .println( "The HTML: " + sContent . substring (nStartSearchAt , nScriptLoc) ) ; 
//System. out .println( "The Script: w + 
sContent. substring* (indexOf IgnoreCase (sContent, , nScriptLoc ) +1) , nEndScriptLoc) ) ; 

nStartSearchAt = nEndScriptLoc + 9; 

nScriptLoc = indexOf IgnoreCase (sContent, "<SCRIPT" , nStartSearchAt) ; 

} 

//sbArticle -append (sContent. substring (nStartSearchAt, nArticleLength - 1) ) ; 
sbArticle. append (sContent .substring (nStartSearchAt, nArticleLength) ) ; //changed by JW 
/ /System. out .print In (sbArticle. toStringO ) ; 
//System. out .print In (sbScripts. toStringO ) ; 

sClientScripts - sbScripts . toString () ; //contains just the scripts' code 
sContent = sbArticle. toString () ; //contains just the article HTML 

} 

catch (Exception e) { 

System . err . print In ( e . getMessage ( ) ) ; 
e .print StackTr ace ( ) ; 

} 

} 

sContent = sContent. replace ( f \r' , ' '); 
sContent = sContent . replace ( ' \n ' , ' '}; 
try { 

sContent = adxTools . swapStrings (sContent, " W " , "WW") ; 
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sContent = adxTools .swaps t rings (sContent, *\ "\W w ) ; 
sContent = adxTools .swapStrings (sContent, "\" n f "\\\" ") ; 

} 

catch (Except ion e) { 

System. err ,println(e.getMessage() ) ; 
e.printStackTrace() ; 

) 

return sClientScripts + " document .write + sContent + "'); " + '\r'; 


} // end class ADPExporter 
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Your Content. Anyplace. Anytime. 


Active Data Randomizer 

User Guide 


Active Data Randomizer gives Users the power 
to keep a Website fresh and inviting to visitors. 
This convenient, easy-to-use tool facilitates the 
collecting, grouping, modifying and removal of 
messages, either graphic or text, that are 
displayed within a page each a time it is loaded, 
reloaded or refreshed by the viewer. 

This User Guide is an overview of how Active Data 
Randomizer works and what it does. For a 
complete demonstration, contact you Active Data 
Exchange representative. 
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Active Data Randomizer 

Overview 

A practical tool, Active Data Randomizer gives Users the power to keep their Website viewers 
attentive to the screen by changing a specific part of a page message each time a viewer refreshes 
or returns to a previously viewed screen. An easy to use tool that requires no additional hardware 
or installation, Active Data Randomizer is platform independent and facilitates the grouping and 
presenting of graphic or text messages on a Website page. 

The Active Data Randomizer allows for direct, targeted message updates, without the complexities 
of publishing completely new pages or documents, from any location with Internet access, at any 
time. Short, catchy visuals and text can be displayed on a page with little effort on the part of the 
client after setup is complete. The random display of messages keeps your page continually 
altering and fresh to viewers as they browse through a site. Using Active Data Randomizer to 
rotate images or messages will decrease the static look and feel of a Web page. 

Step-by-step guide for Active Data Randomizer 

Getting Started 

The Active Data Randomizer is accessible through a Universal Resource Locator, URL. Open your 
Internet browser and enter this URL into the proper area: 

http://pubIisher3.activedatax.com/servlet/com.activedatax.products.BIurb.AdminM 

You will be taken to the main screen for Active Data Randomizer. 


Active Data Randomizer 

Site Configuration Options 

• Add a Hew Site Configuration 

• Change a Site Configuration 

• Delete a Site Configuration. 

• Generate a Site's Administration Code 

Site Blurb Functions for |B|u* Denro 

• Add a New Group 

• Delete a Group 

• View Groups 

• Add a New HTML Bforb 

• View. MocSfV or Delete HTML Blurbs 

• Generate Blurb Code 


Figure 1 Site Configuration Screen 
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The main screen for the Active Data Randomizer has links to each and every functionality offered 
by this time-saving tool. Once you have accessed the Active Data Randomizer tool, you will see all 
the site configuration options and functions that are usable for screen refresh messages. Click on 
any of the bulleted items to access that functionality. 

Stepl Site Set Up 

You will arrive at this window when Add a New Site Configuration is chosen from the Site 
Configuration Screen. From here you are able to set up a new location to display Active Data 
Randomizer messages or return to the Menu. 


Active Data Randomizer 

Add a New Site Configuration 


Site Name I 

Blurbdemo j 

i 

Description! 

Demonstration of Active Data Randomizer j 

Site URL I 

http //asppreview. active datax com/blurbdemo j 


Figure 2 Add a New Site Configuration 

To Set up a new site 

1 . Site Name — enter your new site name. 

2. Descriptions — enter a brief explanation. 

3. Enter the URL to locate the site and the page where you want your dynamic blurbs to be 
displayed 

4. Select the Submit Configuration button 

The new site is automatically configured, and you will be returned to the Administration screen. 

NOTE— the success of your new site set-up is confirmed and expressed by the red text in the 
upper portion of the screen. 

Step 2 Randomizer Groups 

You will arrive at this window when Add a New Group is chosen from the Site Configuration screen. 
From here you are able to set up a new group of Active Data Randomizer blurbs or return to the 
Menu. 
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Active Data Randomizer Administration 
Add a New Blurb Group ta the Site Bhirb Demo 


Group Name|l 02blurb Test 


Figure 3 Add a New Group Name 

Enter a Group Name for your first collection of different blurbs that will be used for a specific 
location. These are the dynamic blurbs that will be rotated sequentially every time a viewer 
returns to that page and it is reloaded, or when the viewer selects the refresh icon. The blurbs 
you want to set up are virtually limitless and can be graphic or textual based. The sample 
group name in this case is 02blurb test. 
Click Submit Group. 


Active Data Randomizer Administration 

The new blurb group Q2bl«rb test was added to the Blurb Demo site 

Site Configuration Options 

• Add a New Site Configuration 
» Change a Site Configuration 

• Delete a Site Configuration 

» Generate a Site's Administration Code 

Site Blurb Functions for |1 

• Add a New Group 

• Delete a Group 

• View Groups 

• Add a New HTML Blurb 

• View. Modify or Delete HTML Blurbs 

• Generate Blurb Code 


Figure 4 New Group Confirmation Message 

3. You will be returned to the main menu. A confirmation that your group has been created is 
shown in red text. It repeats the Group Name and the Site Name that it has been added to. 

4. To continue click on Add a New HTML Blurb, located in the lower group of bulleted items. 
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Step 3 HTML Blurbs 


You will arrive at this window when Add a New HTML Blurb is chosen from the New Group 
Confirmation screen. From here you are able to set up a new location to display Active Data 
Randomizer messages or return to the Menu. 


1 . From the Add a New randomizer screen, select the Group Name from the pull down menu you 
want this new HTML blurb added to. 

2. Enter or Copy and Paste the HTML code for the picture or text or both that you want to show in 
the refreshed window. This information is retrieved from your original document's source code 
from whatever HTML editor program you are using. 
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Figure 6 New Active Data Randomizer Blurb HTML Confirmation 

3. Click on Submit Blurb. A confirmation screen will show that the blurb has been added. 
You are still able to modify or delete your blurb in the future if necessary. Any action you take 
at this step will be confirmed within the next window in red text. 

To add another HTML blurb: 

1 . Click on [Copy] and Randomizer will automatically duplicate your last HTML blurb. 

2. Either insert new HTML text or alter your HTML text, as in the case of changing the image only, 
you can just update the name of the source image, without having to re-enter all new HTML. 

3. Select the Submit Blurb button after each entry to save the changes 
Each entry will be confirmed and added to your list of HTML blurbs. 

4. Repeat this process until you have added ail your HTML blurbs. 

5. Select Go Back to Menu. 


Step 4 Java Script Code 

Once you have returned to the Site Configuration main screen, 

1 . Select Generate Blurb Code from the lower level bulleted options. 

2. Active Data Blurb Admin will automatically write the Java Script needed to instruct your site to 
sequentially rotate the HTML sources. This Java will include ail necessary instructions to 
refresh the image in the window each time it is reloaded or manually refreshed. 
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Active Data Randomizer Administration 

Blurb Machine Code for the Group 02Murb test of the Site Blurb Demo 
(copy and paste into target site's HTML) 


<SCRIPT LANGUAGE="javascript">docun>ent .write 
( f <SCR\IPT LANGUAGE= "javascript" 

SRC^'littp : //publisher 3 . activedatax . coio/servlet/com 
. act ivedatax . products .Blurb . JBlurfo? 
jbsid=860582fiibgid=27122lS3bdurl=' + escape 
( location. href ) + I £3brand= t + escape (Hath. random 
()) + * n ><\/ZCS\lVT> % ) ;</SCRIPT> 


m 


Figure 7 Active Data Randomizer Blurb Code 

3. Highlight and copy this Java Script 

4. Return to your primary source document using your HTML Editing program and select the 
HTML source view. 


^TSXTTi myib<=640 C3L5FAIs=3XA )rj;e£="hDtte hta^ias border=D faeigbt=27 »ic="i»ages/logoa git" 
wi dth= 2 3 9>< /txji lu:e£="paesiiews.hca'"j<IK5 alt=**" i>order*D fceigfcx=27 ste="i»age8/.12paesrieus.g:tf " 
w.dtb=131X/tXA lw:e£-'*port£olionew5.ht*i"><aE& ait'"" botdei:=0 he.giht=2? 

src="iaagc3/12poit£olionew» tjif widths 131x/<o<IH& border =0 3ic»"i»&ge3/12ne»3.gi£ ">-(./ir></7E> 


<-nXD ^XLtCi^topXh fcref="hDne.htjr><HG aIt="PA Early Stage" border-0 heignt 

S£C="iaage3/logo&.gi£" wi<ith=Z39 x/sXBR> 


<tstl* H-ith^239" CSLimCI}iS=Q m,i?£>?IKO0 B:njEF=0>^r>Ctc 7 A LI3?-ti?p 3I?TE«38xmS alt**"* 
border = 0 beight>=275 src*" images /£ adcs. gaf " vidth-38 yAlICH- F, TOP' T ><'td><T& 

Y"ttIGF=top - »<BfCXpX SCRIPT LXRGUAEE<=";) avescript";* document, untt ( '<SCRMJT LAHGUAGE= "javascript" 
SRE>"2sfctp; //JwiWisherJ. *ctiveda t*x.co*/ierr.let/cas- *ctiv>«btdx.pr0d&ct.s.B2uxb. JBlwrfc?jis.td=i3222 Sc 
ji>in cNl Si 63 6* jixterl - r + escape(loc*tion.hrel'} -f ^jhraud=* + escaps{31eth.rsa.doa()) + 

f »x\j5CR\jrT>');</5aarix/i» 



<1T 1£3*TE«aO TAlI^tapXDK botdet=tt heights! src="x»eiges/cle&i . gif" Bldth=lCEX/B> 

<7^ TAtI33*tcp><B3?Xfocc feee»"Ariai, Helvetica, sans-serif »izt'"-l~XJJK ait-"" iotder=B 
™ height=27 sxc="aaages/hrww3.fftf" wldtii»217XP> 
"?H*^i <font color-"«<i4491"XbiXA hrt£-' , paf5nev3.ht»">PA Eotly Stage BewK/ex/KX/tonO 
<P> 

<£o»t col or ="#2d449t "December 4, 20a£KBRxbxA fcraf="pr_a;)untel2&400.bt»r>PA Eaxiy Stage 
■ Company, A junto, Inc., Forms Strategic Alliance vith TerticalBet</aX/f anO</E>Cbrxf ont 



F/gare 8 Sample HTML Editor 


5. Paste the Active Data Randomizer Java script you have copied into your original source 
document for the Web page. 
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NOTE-— Make sure you are within the proper location on your Web page. Paste the script in 
the exact position where you want the message to be displayed on the page. 

6. Exit (or close) your HTML editing program and return to the Active Data Randomizer 
Administration screen. 

7. Click the Return to Menu button. 


Step 5 Verify or Modify Blurb Groupings 


From the main Active Data Randomizer Administration window, you may view your group of 
messages. Active Data Randomizer presents both the HTML and a visual of the output. 

1 . Choose the View, Modify. Delete HTML Blurb to view and confirm your message or messages. 


Active Data Randomizer Administration 

View, [Modify or Delete Blurbs from the Group In the News 


n _ ' ; — — 
\\ Options ■ 

Blur* HTML ; 

Blurb Preview 

t! rcopyi t 

RrModffvl; 
!i TMetel ' 

< img ; 
src="h£tp //www. p ae arlystage. c om/images/logo_airput jpg" I 
border="0"> _ J 


I [Copy] ; 
I [Modify!? 
^Delete]! 

!i 1 

<img j 
src-'httpy/www paearlystage corn/images/logo _gladwyne gif * 
border="0"> i 

GL/0WYNE 

! rcopy] : 

! [Modify]; 

<img : 
src=1ittp://www.paearlystage. com/iniages/pinthenews jpg" 
width=l 80 height 1 58 a!t= H " border="0 B ><BR><font \ 
face— "Anal, Helvetica, sans-senf* size— "-2" > Charlie Clark • 
(VerticalNet), Mchael Carter (Ajunto), Mary Nayior (VTP ; 
Desk), Mike Bofcon</font> j 


InDeleteL 


^^^^^^^^^^^^^ 

Cartel (Ajunto). Maty Nayler(VlP 
Desk), MBte Bolton 


Figure 9 Confirmation and View Message Window 

A preview image of the actual image that will be shown on a viewer's screen. Select Go Back 
to Menu to pretest the messages. 
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Step 6 Rotating Blurbs for Preview 

It is best to always pretest the site to make sure your messages are being presented property. 

1 . Open any separate browser window and point to the page you want to check. 

2. Choose refresh to view the new message in the Group you have been assigned to that page. 
Continue to choose refresh or move to another page and return to the original page to verify 
that your messages have changed. At times it is normal for Active Data Randomizer to repeat 
a message or image. 

3. Exit 

Step 7 Exit 

Users may exit Active Data Randomizer Administration by simply leaving or closing your browser 
window. 


About Active Data Exchange 

Active Data Exchange is a leader in syndication software solutions that empower companies to get 
the right content to the right place at the right time. Active Data Exchange helps create highly 
effective information delivery chains with partners, customers, vendors, distributors, investors, and 
other target groups and affects commerce with communications tools better than existing email 
technologies. The company is active in several industry standards committees including the 
information and Content Exchange Authoring Group and the W3C XML Protocol Standards 
Committee. Clients include Crown, Cork and Seal, MainStreet Networks, Turner Construction, 
Penn Mutual Life Insurance, DeSales and Lehigh University. 
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Title: Active Data Blurb Machine<p> 

Description: Dynamic HTML content generation without the need for a client install .<p> 

Copyright: Copyright (c) John E. Wetzel<p> 

Company: Active Data Exchange, Inc.<p> 

^author: John E. Wetzel 

©version: 1.0a 


V 


package com. activeda tax. products .Blurb; 

import javax.servlet . *,- 
import javax.servlet.http. *; 

import com . activeda tax. products . Blurb. dbmodules . * ; 

import com. act ivedatax. products .Blurb.html . *; 

import com.activedatax. sql .HttpServletDb; 

import com. activedatax.utils .HTMLQuoter; 

import java.io.*; 

import java.net.*; 

import java. util . * ; 

impor t j ava . sql . * ; 

import gnu . regexp . * ; 

import java .net .URL; 

public class AdminMenu extends HttpServletDb { 
private BlurbCommon mycommon; 
private String server = " • ; 
private String dbname = " " ; 
private String thisServlet = " " ; 
private String serverRoot = " " ; 
private String f Link - " " ; 
private String fPost - "" ; 


//Initialize global variables 

public void init {ServletConf ig config) throws ServletException { 
super. init (config) ; 

//USE BlurbCommon. class TO GET PROPERTIES — SERVER & DATABASE NAME 

mycommon - new BlurbCommon ( ) ; 

Properties p = mycommon. get Props () ; 

serverRoot = p.getProperty ( "server .root" } ; 

server = p.getProperty {" de fault. server ") ; 

dbname - p.getProperty { "default .dbname" ) ; 


//store the alias in 

p = mycommon. ge t Al i ases () ; 

thisServlet = p.getProperty { "AdminMenu" ) ; 


fLink - serverRoot + thisServlet ; 
fPost = serverRoot + thisServlet; 

} 


public void doPost (HttpServletRe quest request, HttpServletResponse response) throws 
ServletException, IOException { 

String outputHTML = doBlurb (request , response, this. fLink, this.fPost, false); 

response . setContentType ( " text /html " ) ; 

PrintWriter out = response. getWriter () ; 

/ /System. out. println( request. get Parameter ("jbact" ) ) ; 

out. print In (outputHTML) ; 

return; 


public void doGet (HttpServletRequest request, HttpServletResponse response) throws 
ServletException, IOException { 

String outputHTML = doBlurb ( reques t , response, this. fLink, this.fPost, false); 

response . setContentType ( " text/html " ) ; 

PrintWriter out = response .getWr iter {) ; 

out. println (outputHTML) ; 

return; 
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} 


public String doBlurb (HttpServletRequest request, HttpServletResponse response, String 
forwardLink, String forwardPost, boolean syndicated) throws ServletException, IOException { 
int jbsid, jbgid, jbbid; 
String output HTML = w " ; 
String param = n " ; 

String action = request . getParameter { "jbact") ,- 
try { 

jbsid = Integer. parselnt (request. get Parameter { tt jbsid w ) .trim() ) ; 
} catch (Exception e) { jbsid = -1; } 

try { 

jbgid = Integer. pars elnt (request. getParameter ("jbgid") .trim(}) ; 
} catch (Exception e) { jbgid = -1; } 

try { 

jbbid - Integer .par selnt (request .getParameter f "jbbid" ). trim{ )) ; 
} catch {Exception e) { jbbid = -1; } 

if (jbsid == -1) { //get the blurb_site_id of the first site in the drop-down list box 
jbsid = getFirstSiteld ( ) ; 

} 

if ((action == null) || (action . length ( ) ==0)) { 
out put HTML = 

Ac^iriMenuHTML.getAdminMenu{ jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , " " ,syndicat 
ed) ; 

} 

else { 

if (ac t ion. equal sIgnoreCase( "add") ) { 

out put HTML - AdminMenuHTML . siteAddOrModify ( forwardLink, -1 "http: //","") ; 
} else if (action. equal s IgnoreCase { "addpost" ) ) { 

outputHTML = doSiteAdd( request, response, syndicated); 
} else if (action . equalsIgnoreCase ( "getpostdata" } ) { 

outputHTML = 

AdminMenuHTML. getAdininHenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , nB , syndicat 
ed) ; 

} else if (action. equalsIgnoreCase ( "addbg" ) ) { 
outputHTML = 

AdminMenuHTML. groupAdd( jbsid, -1, forwardLink, forwardPost, " n , getSiteNameFromldt jbsid) , " " ) ; 
} else if (action. equalsIgnoreCase { "addbgpost" ) ) { 

outputHTML = doGroupAdd (request, response, forwardLink, forwardPost, syndicated) ; 
} else if ( action. equalsIgnoreCase ( "addbb" ) ) { 

outputHTML = addBlurb{ jbsid, forwardLink, forwardPost, syndicated) ; 
) else if ( act ion. equal sign or eCa se ( "copybb") > { 

outputHTML = copyBlurb( jbsid, jbgid, jbbid, forwardLink, forwardPost , syndicated) ; 
} else if (act ion. equalsIgnoreCase ( "chgbb" ) ) { 

outputHTML = changeBlurb{ jbsid, jbgid, jbbid, forwardLink, forwardPost, syndicated) ; 
} else if (action. equalsIgnoreCase ( "chgfobpost 2" ) ) { 

outputHTML = doBlurbChange (request , response, forwardLink, forwardPost, syndicated) ; 
} else if ( act ion. equal s Ignor eCase { "addbbpost") ) { 

outputHTML = doBlurbAdd( request, response, forwardLink, forwardPost, syndicated) ; 
} else if (action.equals!gnoreCase( "chg" ) ) { 

outputHTML - changeSiteSelect (syndicated) ; 
} else if (action. equalsIgnoreCase ( *gensitecode tt ) ) { 

outputHTML = genSiteCodeSelect (syndicated) ; 
} else if ( act ion. equal slgnoreCase ( " gens i t ecodepos t 1 ") ) { 

outputHTML = 

AdminMenuHTML. genera teSiteAdminC ode (jbsid, forwardLink, this . serverKoot , g et Si teNameFromld (jbsid) ) ; 
) else if (action. equalsIgnoreCase ( "chgpostl* ) ) { 

outputHTML = changes! teDetails (request, response, syndicated) ; 
} else if (action. equalsIgnoreCase ( M chgpost2" ) ) { 

outputHTML = doSiteChange( request, response, syndicated); 
> else if (action. equalsIgnoreCase ( "del" ) ) { 

outputHTML = deleteSiteSelect (syndicated) ; 

} else if (action. equalsIgnoreCase ( "delbg" ) ) { 

outputHTML = deleteGroupSelect (jbsid, forwardLink, forwardPost, syndicated) ; 
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} else if (action. equals Ignor eCa se ( "delbb" ) ) { 

out put HTML = viewGroupBlurbs (jbsid, jbgid, jbbid, f orwardLink, f orwardPost, "Are you 
<B>sure</B> you want to delete the blurb shown?", syndicated); 
} else if ( act ion. equal s IgnoreCase ( *viewbb n ) ) { 

output HTML = viewBlurbSelect( jbs id, forwardLink, forwardPost, syndicated) ,- 
} else if (action. equals IgnoreCase ( "viewbbpostl * ) ) { 

outputHTML = viewGroupBlurbs (jbsid, jbgid, -1 , f orwardLink, f orwardPost , ' - , syndicated) ; 
} else if { act ion. equals IgnoreCase < "delbgpostl") ) { 

output HTML = 

deleteGroupDetails ( jbsid, forwardLink, f orwardPost, request , response, syndicated) ; 
} else if ( act ion. equal sIgnoreCase( R delbgpost2 " ) ) { 

outputHTML = doGroupDelete{jbsid,forwardLink / forwardPost,request y response, syndicated) ; 
} else if (action. equals IgnoreCase { "delbbpostl" ) ) { 

outputHTML = doBlurbDelete (jbsid, jbgid, jbbid, f orwardLink, f orwardPost, syndicated) ; 
} else if (action. equalsIgnoreCase { "delpostl") ) { 

outputHTML = deleteSiteDetails (request, response, syndicated) ; 
} else if (action.equalsIgnoreCase( "delpost2 " ) ) { 

outputHTML = doSiteDelete (request, response, syndicated) ; 
} else if ( act ion. equal s Ignor eCase ( "genbcode") ) { 

outputHTML = genera teBlurbCode( jbsid, f orwardLink, f orwardPost, syndicated) ; 
} else if ( action. equals Ignor eCas e ( "viewbg" ) ) { 

outputHTML = viewGroups (jbsid, f orwardLink, forwardPost, syndicated) ; 
) else if ( action. equals!gnoreCase( "genbcodepostl" ) ) { 

outputHTML = 

AdminMenuHTML . genera teBlurbCode (jbsid, jbgid, f orwardLink, this . serverRoot , getSi teNameFromld (jbsid) 
getGroupNameFromld (jbgid) ) ; J 
} 

} 

return outputHTML ; 

} 

private synchronized String doSiteAdd (HttpServletRequest request, HttpServletResponse 
response, boolean syndicated) { 
boolean errFlag = false; 
int id = 0; 
int count = 1; 
double tempval; 
Connection conn; 
Vector rs = null; 

BlurbSiteDB bs = new Blurbs i teDB () ; 

String blurb_site_name = r equest.get Parameter ( n blurb_site_name" ) .trim() ? 
String description = request .get Parameter ( "description" ). trim () ; 
String url = request .get Parameter ( "url " ) - trim {) ; 

/* 

Test if site, desc, and http:// are valid 
*/ 

try { 

if (blurb_site_name . trim{ } . equals IgnoreCase ( " " ) ) { 

return AdminMenuHTML. si teAddOrModify { this . serverRoot + this . thisServlet , -1, 
blurb_site_name, description, url, "An error occured. An invalid <B>Site Name or Site 
Description</B> was entered.") ; 

} 

if (description. trim() .equal sIgnoreCase( " *) ) { 

return AdminMenuHTML. si teAddOrModify (this . serverRoot + this . thisServlet, -1, 
blurb_site_name, description, url, "An error occured. An invalid <B>Site Name or Site 
Description</B> was entered.") ; 

} 

} 

catch (Exception e) { 

BlurbCommon.handleException(e) ; 

return AdminMenuHTML .si teAddOrModify (this. serverRoot + this . thisServlet, -1, 
blurb_site_name, description, url, *An error occured. An invalid <B>Site Name' or Site 
Description</B> was entered. 11 ) ; 
> 

/* 

Test for a valid URL 
*/ 
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if (url. length () > 9) { 

if (url. substr ing (0, 7) .equals IgnoreCase ( "ht tp://°) ) { 
} else if (url. substring (0,8) .equalsIgnoreCaseChttps ://")) { 
} else { 

return AdminMenuHTML. siteAddOrModif y ( this . serverRoot + 
this. this Servlet, -l,blurb_sit e_name, description, url, "An error occurred 
URL</B> was entered."); 
3 

} else { 

return AdminMenuHTML . si teAddOrModi f y { this . serverRoot + 
this.thisServlet, -1 , blurb_site_name, description, url, "An error occurred 
URL</B> was entered."); 
} 

if { lurl.subst ring (0, 5) .equal s IgnoreCase { "https" ) ) { 
try { 

URL testURL = new URL (url ); 

} 

catch (Exception e) { 

BlurbCommon.handleException (e) ; 

return AdminMenuHTML . si teAddOrModif y { this . serverRoot + 
this.thisServlet, -l,blurb_site_name, description, url, "An error occurred 
TJRL</B> was entered."); 
} 

} 

/* 

Pick a random id for blurb_site and make sure that a record with 
that id doesn't already exist. 
*/ 

conn = dataConnMan.getConnect ion (server, dbname) ; 
while (count > 0) { 

tempval = Math. floor (1000000 * Math .random () ) ; 

id = (int) tempval; 

try { 

rs = bs.getAll(conn, **blurb„site_id = * + id); 
} catch (Exception e) { 

BlurbCommon.handleException (e> ; 
break ; 

) 

count = rs.sizeO; 

} 

dataConnMan . f reeConnection { server , dbname, conn) ; 
if (count > 0) 

return AdminMenuHTML. get AdminMenu ( getFirstSiteId( ) , this . serverRoot + this.thisServlet, 
getSiteSelectList (getFirstSiteldO , true, syndicated) , "An error occurred. The new site 
configuration was not added . * , syndicated) ; 

/* 

Make sure that blurb_site_name doesn't already exist in the database. 
*/ 

conn = da t aConnMan . ge t Conne c t i on ( s erver , dbname ) ; 
try { 

//blurb_site_name = new RE {"'"). substituteAll {blurb__site_name, "''"); 

rs = bs.getAll(conn, n blurb_site_name = + new RE { *' * ). substituteAll (blurb_s it e_name, 
+ .,. ); 

} catch (Exception e) { 

BlurbCommon . hand leBxcept ion (e) ; 
errFlag = true; 

} 

dataConnMan . f reeConnection (server , dbname, conn) ; 

if(rs.size() > 0} 

return AdminMenuHTML . s i teAddOrModi f y ( this . serverRoot + 
this.thisServlet, -1 f blurb_site_name, description, url, tt The site <B>" + blurb_site_name + "</B> 
already exists. Please try again. M ); 

if (errFlag) 

return AdminMenuHTML. ge tAdminMenu (getFirs t Sit eld () , this .serverRoot + this.thisServlet, 
getSiteSelectList (getFirstSiteld ( ) , true, syndicated) , "An error occurred. The new site 
configuration was not added. syndicated) ; 


An invalid <B>Site 


An invalid <B>Site 


An invalid <B>Site 
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//attempt to do the database insert of the new blurb_site record; 

bs .blurb_site_id = id; 

bs.blurb_site_name = blurb_site_name; 

bs. description = description; 

bs.url = url; 

bs. status = "Y 9 ; 

bs~created_on = new java .util .Date { ) ; 

bs . 1 as t_modi f ied_on = new j ava . u t i 1 - Da t e { ) ; 

conn = dataConnMan. get Connect ion (server, dbname) ; 
try { 

bs . insert (conn) ; 
} catch (Exception e) { 

BlurbCommon.handleException (e) ; 

errFlag - true; 

} 

dataConnMan . f reeConnection ( server/ dbname, conn) ; 
if (errFlag) 

return AdminMenuHTML. ge tAdminMenu (getFirstSiteldO , this . serverRoot + this . thisServlet, 
getSiteSelectList (getFirstSiteldO , true, syndicated) , "An error occurred. The new site 
configuration was not added. " , syndicated) ; 
else 

return AdminMenuHTML . ge tAdminMenu {getFirstSiteld { ) , this. serverRoot + this. thisServlet, 
getSiteSelectList (getFirstSite!d( ), true, syndicated) , "The new site configuration for <B>" + 
blurb_site_name + "</B> was added successf ully. n , syndicated) ; 
} 

private synchronized String doGroupAdd(HttpServletRequest request, HttpServletResponse 
response, String forwardLink, String forwardPost, boolean syndicated) { 
boolean errFlag = false; 
int id = 0; 
int count = 1; 
double tempval ; 
Connection conn; 
Vector rs = null ; 

B 1 ur bGr oupDB bg = new BlurbGroupDB { ) ; 

int jbsid = Integer .parselnt (request . getParameter (" jbsid" ). trim ()) ; 
String blurb_group__name = request . getParameter ( "blurb_group_name * ) . trim { ) ; 
//String description = request . getParameter { "description" ). trim () ; 

if (blurb_group„name == null) { 
return 

AdminMenuHTML . groupAdd ( jbsid, -1, forwardLink, forwardPost ,blurb„group_name, getSiteSelectList (jbsid, 
false, syndicated) , "An Invalid blurb group name. Please try again. "); 
} else if {blurb_group_name . tr im ( } . equal s Ignor eCase (" ") ) { 
return 

AdminMenuHTML . groupAdd (jbsid, -1 , forwardLink, forwardPost , blurb_group_name, getSiteSelectList ( jbsid, 
false, syndicated) , "An Invalid blurb group name. Please try again,"); 
} 

/* 

Pick a random id for blurb_group and make sure that a record with 

that id doesn't already exist. 

*/ 

conn = dataConnMan .getConnect ion (server, dbname) ; 
while (count > 0) { 

tempval = Math . floor (1000000 * Math . random ( ) ) ; 

id = (int) tempval ; 

try { 

rs = bg. get All (conn, "blurb_group__id = " + id) ; 
> catch (Exception e) { 

BlurbCommon . handleExcept i on { e ) ; 
break; 

} 

count = rs.sizeO; 

> 

dataConnMan . f reeConnection (server , dbname, conn) ; 
if (count > 0) 
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return 

AdminMenuHTML. getAdminMenu ( jbsid, f orwardLink, getSiteSelectList (getPirstSiteId( ) , true, syndicated) , 
"An error occurred. The new blurb group was not added. " , syndicated) ; 

/* 

Make sure that blurb_group_name doesn't already exist in the database 
*/ 

conn = da taConnMan . getConnect ion (server, dbname) ; 
try { 

rs = bg.getAlMconn, "blurb_group_name = + new RE ( " } - substi tuteAll (blurb group name, 
*"") + "'"); 

} catch {Exception e} { 

BlurbCommon.handleException (e) ; 
errFlag = true; 

} 

da taConnMan . f reeConnection { server r dbname, conn) ; 

if(rs.size() > 0) 
return 

AdminMenuHTML. groupAdd (jbsid, -1 , f orwardLink, forwardPost, blurb_group_name, getSiteSelectList (jbsid, 

false, syndicated) , "The group <B>" + blurb_group_narne + B </B> already exists. Please try 
again. ") ; 

if (errFlag) 
return 

AdminMenuHTML. getA<tai^ f BAn error 

occurred. The new blurb group was not added, * , syndicated) ; 

//attempt to do the database insert of the new blurb_group record; 
bg.blurb_site_id = jbsid; 
bg . blurb_group_id = id; 

bg.blurb_group_name = blurb_group_naine; 
//bg. description = description ; 
bg. status = "Y"; 

bg.created^on = new java .util .Date ( ) ; 

bg . last_modif ied_on = new java. util .Date () ; 

conn = da taConnMan. getConnect ion (server, dbname) ; 
try { 

bg. insert (conn) ; 
} catch (Exception e) { 

BlurbCommon.handleException (e) ; 

errFlag = true; 

> 

dataConnMan. f reeConnection (server , dbname, conn) ; 

if (errFlag) 
return 

AdminMenuHTML. getAdminMenu (jbsid, f orwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred. The new blurb group was not added. syndicated) ; 
else 
return 

AdminMenuHTML. getAdminMenu (jbsid, f orwardLink, getSiteSelectList (jbsid, true, syndicated) , "The new 
blurb group <B>" + blurb_group_name + n </B> was added to the <B> R + getSiteNameFromId( jbsid) + 
*</B> site. " , syndicated) ; 
> 

private synchronized String doBlurbAdd (HttpServletRequest request, HttpServletResponse 
response. String f orwardLink, String forwardPost, boolean syndicated) { 
boolean errFlag = false ; 
int id = 0; 
int count = 1 ; 
double tempval; 
Connection conn; 
Vector rs = null; 
BlurbDB bb = new BlurbDB £ ) ; 

GregorianCalendar gc = new GregorianCalendar () ; 

int jbsid - Integer .pars elnt (request .getParameter { "jbsid" ). trim{ )) ; 
int jbgid = Integer. par selnt (request .getParameter ( "jbgid" ). trim{ )) ; 

String html = r equest. get Parameter { "html") . trim( ) ; 
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/* 

Pick a random id for blurb and make sure that a record with 

that id doesn't already exist. 

*/ 

conn = da taConnMan. get Connect ion {server, dbname) ,- 
while (count > 0) { 

tempval = Math. floor (1000000 * Math. random (} ) ; 

id = (int) tempval ; 

try { 

rs = bb.getAlMconn, "blurb_id = n + id); 
} catch (Exception e> { 

BlurbCommon . handleExcept i on ( e ) ; 
break ; 

} 

count = rs.sizeO ; 

} 

da taConnMan . f reeConnection ( server , dbname , conn ) ; 
if (count > 0) 
return 

AdminMenuHTML . getAdminMenu (jbsid, forwardLink,getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred. The new blurb was not added. syndicated) ; 

//attempt to do the database insert of the new blurb record ; 

bb.blurb_site_id = jbsid; 

bb.blurb_group_id = jbgid; 

bb.blurb_id = id; 

bb.html = html ; 

bb. status = "Y" ; 

/ /bb . created_on = new j ava . util . Date { ) ; 

bb . created_on = new Timestamp ( gc . getTime ( ) . getTime ( ) ) ; 

bb. last__modif ied_on = new Timestamp (gc .getTime {). getTime {)) ; 

conn = da taConnMan. get Connect ion (server , dbname); 
try { 

bb. insert (conn) ; 
} catch (Exception e) { 

BlurbCommon. handleException(e) ; 

errFlag - true; 

> 

da t aConnMan. freeConnec t ion {server, dbname, conn); 

if (errFlag) 
return 

AdminMenuHTML. getAdminMenu {jbsid, f orwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred. The new blurb was not added. " , syndicated) ; 
else 

return viewGroupBlurbs (jbsid, jbgid, -1, f orwardLink, forwardPost, "The new blurb was added 
successfully. " , syndicated) ; 
} 

private String doSiteChange (HttpServletRequest request, HttpServletResponse response, boolean 
syndicated) { 

boolean errFlag = false; 
Connection conn; 
Vector rs = null; 

BlurbS iteDB bs - new BlurbSiteDB ( ) ; 

int id = Integer.parselnt ( request. getParameter( n jbsid") .trim() ) ,- 
int tempid = id; 

String blurb_site_name = reques t. get Parameter ( "blur^site^name") . trim( ) ; 
String description = request .get Parameter { "description") . trim() ; 
String url = request .getParameter { "url" ). trim () ; 


/* 

Test if site, desc, and http:// are valid 
*/ 

try { 

if (blurb_site_name. trim() . equal s!gnoreCase( BR ) ) { 
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return AdminMenuHTML. siteAddOrModify { this - serverRoot + this . thisServlet , id, 
blurb_site_name, description, url, "An error occured. An invalid <B>Site Name or Site 
Description</B> was entered- B ) ; 
} 

if {description. trim () . equal slgnoreCase p n ) ) { 

return AdmiiiMenuHTML. siteAddOrModify (this . serverRoot + this . thisServlet , id, 
blurb_site_name, description, url, "An error occured. An invalid <B>Site Name or Site 
Description</B> was entered.") ; 

} 

> 

catch {Exception e) { 

BlurbCommon.handleException (e) ; 

return AdminMenuHTML. siteAddOrModify (this .serverRoot + this. thisServlet , id, 
blurb„site_name, description, url, "An error occured. An invalid <B>Site Name or Site 
Description</B> was entered.") ; 
} 

/* 

Test for a valid URL 
*/ 

if (url. length 0 > 9) { 

if (url. substring (0,7) .equal sIgnoreCase( "http://"}) { 
} else if (url. substring (0,8) .equals IgnoreCase ( "https ://*) ) { 
} else { 

return AdminMenuHTML. siteAddOrModify (this. serverRoot + 
this . thisServlet , id, blurb_s it e__name, description, url , "An error occurred 
URL</B> was entered."); 
} 

} else { 

return AdminMenuHTML .siteAddOrModify ( this . serverRoot + 
this. thisServlet, id, blurb__site_name, description, url, "An error occurred 
URL</B> was entered. "); 
} 

if {! url. substring (0, 5) . equalsIgnoreCase { "https" ) ) { 
try { 

URL testURL = new URL (url }; 

} 

catch (Exception e) { 

BlurbCoirtmon.handleException(e) ; 

return AdminMenuHTML . siteAddOrModify ( this . serverRoot + 
this. thisServlet , id, blurb_site_name, description, url, "An error occurred 
URL</B> was entered."); 
} 

> 

/* 

Make sure that the new blurb_site_name doesn't already exist in the database. 
*/ 

conn = da taConhMan . getConnect ion (server, dbname) ; 
try { 

//blurb_site_name = new RE ("'"). subs t i tut eAll (blurb_site_name, * ' ' " ) ; 

rs = bs.getAll (conn, B blurb_site_name = '» + new RE ( " '■>. subs ti tut eAll (blurb_site_name, 
" " " ) + " ' - ) ; 

} catch (Exception e) { 

B 1 urbCommon . handl eExcep t i on { e ) ; 
errFlag = true; 

> 

dataConnMan . f reeConnect ion ( server, dbname, conn ) ; 
if (errFlag) 

return AdminMenuHTML. get AdminMenu(ge tFirstSite!d{ ) , this . serverRoot + this . thisServlet, 
getSiteSelectList (getFirstSiteId{ ), true, syndicated) , "An error occurred. The site configuration 
change was not completed. syndicated) ; 

if(rs.size{) > 0) { 

Enumeration e - rs . elements {) ; 
while (e.hasMoreElements{) ) { 

BlurbSiteDB record = (BlurbSiteDB) e.nextElement ( ) ; 

tempid = record.fc>lurb_site__id; 

} 


An invalid <B>Site 


An invalid <B>Site 


An invalid <B>Site 
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if(tempid != id) 

re turn AdminMenuHTML . s i t eAddOrModi f y { thi s . server Root + 
this . thisServlet, id ,blurb_site_name, description, url, "The site <B>" + blurb_site_name + "</B> 
already exists. Please try again."); 
} 

//attempt to do the database update of the modified blurb_site record; 

bs .blurb_site_id = id; 

bs.blurb_site_name = blurb_site__name; 

bs. description = description; 

bs.url = url; 

bs. status = n Y"; 

bs . created_on = new java . util . Date ( ) ; 

bs . last_modif ied_on = new java. util. Date () ; 

conn = da taConnMan.getConnect ion (server, dbname) ; 
try { 

bs .update (conn) ; 
} catch {Exception e) { 

B lurbCommon . handl eExc ep t i on { e ) ; 

err Flag = true; 

} 

dataConnMan . f reeConnect ion (server , dbname, conn) ; 
if (errFlag) 

return Ad^inMenuHTML.getAdininMenu(getFirstSiteId( ) , this . serverRoot + this . thi sServlet, 
getSiteSelectList (getFirstSiteld { ) , true, syndicated) , "An error occurred. The site configuration 
was not changed. " , syndicated) ; 
else 

return AdminMenuHTML.getAdminMenu (getFirstSiteld ( ) , this . serverRoot + this . thisServlet, 
getSiteSelectList (getFirstSiteld { ) , true, syndicated) , "The site configuration for <B>" + 
blurb_site_name + "</B> was changed successfully . n , syndicated) ; 
} 

private String doBlurbChange (HttpServletRequest request, HttpServletResponse response, String 
forwardLink, String forwardPost, boolean syndicated) { 
boolean errFlag = false; 
Connection conn; 
Vector rs ~ null; 
BlurbDB bb = new BlurbDB ( ) ; 

int jbsid = Integer .parselnt (request .get Parameter { "jbsid" ). trim ()) ; 
int jbgid = Integer .parselnt (request .getParameter { "jbgid" ). trim ()) ; 
int id = Integer. parselnt {request. getParameter ("jbbid" )- trim{) ) ; 
int tempid = id; 

String html = request . getParameter ( "html "). trim( ) ; 


//attempt to do the database update of the modified blurb record; 

bb.blurb_id - id; 

bb.blurb_group__id = jbgid; 

bb.blurb_site_id = jbsid; 

bb.html = html; 

bb. status = n Y"; 

bb. created_on = new java. util. Datef) ; 

bb . las t_modi f i ed_on = new j ava . u t i 1 . Da te ( > ,- 

conn = da taConnMan.getConnect ion (server, dbname); 
try { 

bb . upda t e { conn ) ; 
} catch (Exception e) { 

BlurbCommon . handleExcept ion ( e ) ; 

errFlag = true; 

} 

dataConnMan . f reeConnect ion ( server , dbname , conn) ; 

if (errFlag) 
return 

AdminMenuHTML . getAdminMenu {jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred. The blurb was not changed. n , syndicated) ; 
else 
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//return AdminMenuHTML.getAdminMenu ( jbsid, this.serverRoot + this. this Servlet, 
getSiteSelectList ( jbsid, true) , "The blurb was changed successfully."}; 

return viewGroupBlurbs (jbsid, jbgid, -1, forwardLink, forwardPost, "The blurb was changed 
successfully. M , syndicated) ; 
} 

private String doSiteDelete (HttpServletRequest request, HttpServletResponse response, boolean 
syndicated) { 

boolean err Flag = falser- 
Connection conn; 
Vector rg = null, rb = null; 
BlurbSiteDB bs = new BlurbSiteDB{ ) ; 
BlurbDB bb = new BlurbDB { ) ; 
BlurbGroupDB bg = new BlurbGroupDB { ) ; 

int id - In teger. parselnt ( request. get Parameter ( "jbsid") .trim ()) ; 

//attempt to delete the blurb_site record and all associated blurb_group and blurb records; 
bs -blurb_sxte_id = id; 

conn = da taConnMan.getConnect ion (server, dbname); 
try { 

rb = bb.getAll (conn, *blurb_site_id=* + id); 
rg = bg. get All (conn, B blurb_site__id=" + id) ; 
if(rb.size() > 0) { 

Enumeration q = rb. elements {) ; 
while (q.hasMoreElements { ) ) { 

BlurbDB b_record = (BlurbDB) q. next Element ( ) ; 
b_record . delete ( conn) ; 

} 

> 

if(rg.size() > 0} { 

Enumeration x = rg. elements () ; 
while {x.hasMoreElements ( ) ) { 

BlurbGroupDB g_record = (BlurbGroupDB) x.nextElement { ) ; 

g_record. delete (conn) ; 

} 

} 

bs . del ete ( conn ) ; 

} catch {Exception e) { 

BlurbCommon .handleException (e) ; 
errFlag = true; 

} 

da taConnMan . f reeConnect ion (server , dbname , conn ) ; 
if (errFlag) 

return AdminMenuHTML.getAdminMenu (getFirstSiteId{ ) , this.serverRoot + this. thisServlet, 
getSiteSelectList (getFirstSiteld { ), true, syndicated) , "An error occurred. The site configuration 
was not deleted. M , syndicated) ; 
else 

return AdminMenuHTML . get AdminMenu (getFir st Sit eld() , this.serverRoot + this . thisServlet, 
getSiteSelectList (getFirstSiteld ( ) , true, syndicated) , "The site configuration was deleted 
successfully. " , syndicated) ; 
} 

private String doGroupDelete(int jbsid, String forwardLink, String forwardPost, 
HttpServletRequest request, HttpServletResponse response, boolean syndicated) { 
boolean errFlag = false; 
Connection conn; 
Vector rb = null; 
BlurbDB bb ~ new BlurbDB ( ) ; 
BlurbGroupDB bg = new BlurbGroupDB { ) ; 

int id = Integer .parselnt (request .getParameter ( "jbgid" ). trim( )) ; 

//attempt to delete the blurb_group record and all associated blurb records; 
bg . blurb_group_id - id; 

conn ~ dataConnMan .getConnect ion (server, dbname); 
try { 

rb = bb.getAll (conn, "blurb_site_id- n + jbsid + " and blurb„group_id = " + id); 
if(rb.size() > 0) { 
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Enumeration q = rb. elements () ; 
while {q.hasMoreElements {) ) { 

BlurbDB b_record = (BlurbDB) q.nextElement {) ; 

b_record . delete ( conn) ; 

} 

} 

bg. delete (conn) ; 

} catch (Exception e) { 

BlurbCommon . handl eExcept i on ( e ) ; 
errFlag = true; 

} 

dataConnMan. freeConn ect ion (server, dbname, conn); 

if (errFlag) 
return 

Admi]^enuHTML,getAdminMenu (jbsid, f orwardLink,getSiteSelectList { jbsid, true, syndicated) , "An error 
occurred. The group was not deleted. M , syndicated) ; 
else 
return 

AdminMenuHTML. get AdminMenu (jbsid, f orwardLink,getSiteSelectList (jbsid, true, syndicated) , "The group 
was deleted successfully syndicated) ; 
} 

private String doBlurbDelete (int jbsid, int jbgid, int jbbid, String forwardLink, String 
forwardPost, boolean syndicated) { 
boolean errFlag = false; 
Connection conn; 
Vector v = null; 
BlurbDB bb = new BlurbDB { ) ; 

//attempt to delete the blurb record 
bb.blurb_id = jbbid; 

conn = da taConnMan. get Connect ion (server, dbname); 
try { 

bb. delete (conn) ; 
} catch (Exception e) { 

BlurbCommon . handl eExcept i on ( e ) ; 

errFlag = true; 

} 

da t aConnMan. freeConnec t ion (server, dbname, conn) ; 

if (errFlag} 
return 

AdminMenuHTML. getAdminMenu (jbsid, f orwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred. The blurb was not deleted. w , syndicated) ; 
else 

return viewGroupBlurbs (jbsid, jbgid, -1 , forwardLink, forwardPost, "The blurb was deleted 
successfully. " , syndicated) ; 
} 


//private String getSiteSelectList (int jbsid, boolean syndicated) { 

//return getSiteSelectList (jbsid, false, syndicated) ; 
//} 

private int getFirstSiteldf ) { 
boolean errFlag = false; 
boolean first = true; 
int id = -1; 

BlurbSiteDB bs = new BlurbSiteDB () ; 
Vector v = null; 

Connection conn = dataConnMan .getConnect ion (server, dbname) ; 
try { 

v = bs.getAll (conn, "1=1 order by blurb_site_name asc"); 
} catch (Exception e) { 

BlurbCommon . handl eExcept ion ( e) ; 
errFlag = true; 

> 

da t a ConnMan. freeConnec t ion (server, dbname, conn); 
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if (err Flag) 
return -1; 

Enumeration e = v. elements {) ; 
if {v.sizeO > 0) { 

while (e.hasMoreElements { ) } { 

BlurbSiteDB record = (BlurbSiteDB) e. next Element O ; 
if (first) 

id = record. blurb_site_id; 
first = false; 

} 

} else { 
id = -1; 

} 

return id ; 


private String getSiteNameFromldfint jbsid) { 
boolean errFlag = false ; 
String blurb_site_name = nn ; 
BlurbSiteDB bs = new BlurbSiteDB () ; 
Vector v = null; 

Connection conn = dataConnMan. get Connect ion (server, dbname) ; 
try { 

v = bs .getAll (conn, tt blurb_site__id = w + jbsid) ; 
} catch (Exception e) { 

BlurbCommon .handleException (e) ; 
errFlag = true; 

} 

dataConnMan. freeConnect ion (server , dbname , conn); 

if (errFlag) 

return "error"; 

Enumeration e = v. elements () ; 
if(v.size() > 0) { 

while (e.hasMoreElements {) ) { 

BlurbSiteDB record = (BlurbSiteDB) e .nextElement ( ) ; 

blurb__site_name = record.blurb_site_name; 

} 

} else { 

bl urb_s i t e_name = "error"; 

> 

return blurb_site_name; 


private String getGroupNameFromld ( int jbgid) { 
boolean errFlag = false; 
String blurb group name = " n ; 
BlurbGroupDB bg = new BlurbGroupDB { ) ; 
Vector v = null; 

Connection conn = dataConnMan. getConnection (server, dbname); 
try { 

v = bg. getAll (conn, n blurb_group_id - " + jbgid) ; 
} catch (Exception e) { 

B lurbCommon . handl eExc ep t i on ( e ) ; 
errFlag = true; 

} 

dataConnMan. freeConnect ion (server , dbname, conn); 

if (errFlag) 

return " error ■ ; 

Enumeration e = v. elements (} ; 
if {v.sizeO > 0) { 

while (e.hasMoreElements {) ) { 

BlurbGroupDB record = (BlurbGroupDB) e. next Element {) ; 

blurb_group__name = record . blurb_group__name ; 

} 
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} else { 

blurb_group„name = "error"; 

} 

re turn bl ur b_gr oup_n ame ; 


private String getBlurbHTMLFromld { int jbbid) { 
boolean errFlag = false ; 
String html = ""; 
BlurbDB bb - new BlurbDB ( ) ; 
Vector v = null; 

Connection conn - da taConnMan.getConnection (server, dbname) ; 
try { 

v = bb. get All (conn, "blurb_id = w + jbbid) ; 
} catch (Exception e) { 

BlurbCoinmon . handleExcept ion { e ) ; 
errFlag = true; 

} 

da t aConnMan. freeConnec t ion (server, dbname, conn) ; 

if (errFlag) 

return "error"; 

Enumeration e = v. elements () ; 
if(v.size() > 0) { 

while (e.hasMoreElements () ) { 

BlurbDB record = (BlurbDB) e.nextElement ( ) ; 

html = record.html; 

} 

} else { 

html = " error " ; 

} 

return html; 

} 

private String getSiteSelectList ( int jbsid, boolean include Java script , boolean syndicated) 
boolean errFlag = false ; 
boolean first = true; 
BlurbSiteDB bs = new BlurbSiteDB () ; 
Vector v = null; 

if (syndicated) 

return getSiteNameFromld { jbsid) ; 
else { 

Connection conn = da t aConnMan. getConnect ion (server, dbname); 
try { 

v = bs.getAll(conn, "1-1 order by blurb_site_name asc"); 
} catch (Exception e) { 

BlurbC ommon. handleExcept i on (e) ; 
errFlag = true; 

} 

da t aC onnMan . f r eeC onn ec t i on ( s erver , dbname , conn ) ; 

if (errFlag) 

return "error"; 

Enumeration e = v. elements () ; 
StringBuffer sb = new Str ingBuf f er ( ) ; 
StringBuffer jPararos = new StringBuf fer () ; 
StringBuffer js = new StringBuf fer () 

if(v.size() > 0) { 

if { includeJavascript) 

sb.append( "< SELECT NAME=\" jbsid\ " onChange=\ " jgo ( this, 1, false)\ n >" + '\r'); 
else 

sb. append {*< SELECT NAME=\ "jbsid\ B >" + '\r'); 
while (e.hasMoreElements {) ) { 

BlurbSiteDB record = (BlurbSiteDB) e.nextElement {) ; 
if (first) 

j Params . append ( "\"\ " ,\** + this . serverRoot + this . thisServlet + "?jbsid= B + 
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record. blurb_site_id + ; 
else 

jParams.append( B , \" " + this . serverRoot + this .this Servlet + "Tjbsid^" + 
record . blurb_si te_id + * \ " ■ ) ; 

if {(first) &fc (includeJavascript)) 

sb. append ( tt < opt ion value^VX^Select a site »</option> B + '\r'); 
if (jbsid == record. blurb_site_id) 

sb. append {"< opt ion value=\" - + record.blurb_site__id + n \ n selected>* + 
record. blurb_site_name + "</option>" + '\r'); 
else 

sb. append ("< opt ion value=\"" + record. blurb_site_id + "\">" + record.blurb_site_i 
+ *</option>" + '\r'); 

first = false; 

} 

sb . append ("</ SELECT> " + ' \r ' ) ; 

if (includeJavascript) { 

String redirParams = j Par ams . toString () ; 

js. append ( n <SCRIPT language=\"JavaScriptl.2\ + '\r'); 

js. append {" function buildArrayO {" + ' \r'); 

js. append ("var a = buildArray. arguments ; n + '\r'); 

j s . append (" for (i=0; i<a. length; i++> {" + '\r'); 

js.append( n this(i] = a[i];" + '\r'); 

j s . append ( " } " + ' \r ' } ; 

j s. append { "this. length = a. length;" + r \r'); 
j s . append ("} n + ' \r ' ) ; 

j s. append ( "var urlsl = new buildArray (■ + redirParams + ");" + ' \r'); 
// System. out. print In (redirParams) ; 

j s. append { "function jgofwhich, num, win) { n + '\r'); 
js. append ("n = which. select edlndex; * + '\r'); 
j s. append ( "if {n != 0) {" + '\r'); 

js .append{ "var url = eval { \ "urls\ " + num + \"En}\")" + '\r'); 

js. append {"if (win) { " + '\r'); 

j s . append ( " openWindow ( url ) ; n + ' \r ' ) ; 

js.append("} else {" + '\r'); 

js. append ("location. href = url;" + '\r'); 

j s . append { " } " + '\r'); 

j s . append ( " } * + ' \r ' ) ; 

j s . append ( * } n + ' \r ' ) ; 

js .append ( n </SCRIPT> w + '\r'); 

} 

} else { 

return "none"; 

} 

return js . toString ( ) + sb. toString { ) ; 

> 

} 

private String getGroupSelectList (int jbsid, int jbgid) { 
boolean errFlag = false- 
boolean first = true; 

BlurbGroupDB bg = new BlurbGroupDB ( ) ; 
Vector v = null; 

Connection conn = da taConnMan . getConnect ion (server, dbname) ; 
try { 

v = bg. get All (conn, "blurb_site_id = B + jbsid + " order by blurb_group_name asc"); 
} catch (Exception e> { 

BlurbCommon . handleExcepti on ( e ) ; 
errFlag = true; 

} 

da t aC onnMan. f reeConnect ion (server , dbname, conn) ; 

if (errFlag) 

return "error"; 

Enumeration e = v. elements () ; 
StringBuffer sb = new StringBuf f er ( ) ; 
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if(v.sizef) > 0) { 

sb.append( n <SELECT NAME=\ tt jbgid\ tt >» + '\r'); 
while ( e . hasMoreElements ( } ) { 

B lu rbGr oupDB r ecor d = ( B lurfoGr oupDB ) e . next E 1 emen t { ) ; 

//if (first) 

/ /sb. append ( w <opt ion valuer \ " \ *>Select a site »</option>" + '\r'); 
if (jbgid == record .blurb_group_id) 

sb. append ( "<option value=\ Hn + re cord. blur b_group_id + "\ n selected>* + 
record. blurb_group_name ,, </option> n + '\r'); 
else 

sb. append ( w <opt ion value-\ nn + record . blurb_group_id + n \ M > n + record. blurb„group_name 
+ "</option> w + '\r'); 

first = f alse; 

} 

sb. append (" </SELECT>" + '\r'>; 
} else { 

return "none" ; 

} 

return sb. toString ( ) ; 

} 

private String viewGroups ( int jbsid, String forwardLink, String forwardPost, boolean 
syndicated) { 

boolean errFlag = false; 
BlurbGroupDB bg = new BlurbGroupDB ( ) ; 
BlurbDB bb - new BlurbDB ( ) ; 
Vector v = null, z = null; 

Connection conn = dataConnMan.getConnect ion (server, dbname); 
try { 

v - bg .getAll (conn, "blurb_site_id = H + jbsid + H order by blurb_group_name asc"); 
} catch (Exception e) { 

BlurbCommon . handl eExcept i on { e ) ; 
errFlag = true; 

} 

da t aConnMan . freeConnec t ion (server, dbname, conn); 

Enumeration e - v. elements () ; 
StringBuffer sb = new StringBuf f er ( ) ; 

if(v.size{) > 0) { 

conn = da taConnMan . getConnect ion (server, dbname) ; 
while (e. hasMoreElements ( ) ) { 

BlurbGroupDB record = (BlurbGroupDB) e . nextElement { ) ; 
try { 

z = bb. get All (conn, n blurb_site_id = rt + jbsid + n and blurb group id = " + 
record . blurb_group_id ) ; 

sb.append( "<trxtd align=left>&nbsp;&nbsp;&nbsp; n + record . blurb_group_name + 
*</td><td align=lef t>&nbsp;&nbsp;&nbsp; " + z.size(} + ,, </td></tr> ,, + '\r'); 
} catch (Exception ex) { 

BlurbCommon. handl eExcept ion (ex) ; 

errFlag = true; 

} 

> 

dat aConnMan. freeConnec t ion {server, dbname, conn) ; 
} else { 
return 

AdminMenuHTML . getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "Ho groups 
are currently configured. Please add a new group. syndicated) ; 
} 

if (errFlag) 
return 

AdminMenuHTML. getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database . syndicated) ; 
else 
return 

AdminMenuHTML. viewGroups (jbsid, f orwardLink, f orwardPost , sb. toString ( ) , getSiteNameFromld (jbsid) ) ; 
} 

private String changes i teDeta il s (HttpServletReguest request, HttpServletResponse response, 
boolean syndicated) { 
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boolean err Flag = false; 

int id = Integer. parselnt ( request. getParameter ( " jbsid" ) .trim ()) ; 
String blurb_site_name = 
String description = " " ; 
String url = " " ; 
Vector rs = null; 

BlurbSiteDB bs = new BlurbSiteDB () ; 

Connection conn = da taConnMan .get Connect ion (server, dbname) ; 
try { 

rs = bs .getAll {conn, w blurb_site_id = " + id); 
} catch (Exception e) { 

BlurbCommon.handleException (e) ; 
errFlag = true; 

} 

da taConnMan. freeConnect ion {server, dbname, conn) ; 
if (errFlag) 

return AdminMenuHTML . getAdminMenu (getFirstSiteld ( ) , this.serverRoot + this . thisServlet , 
g etSiteSelectList(getFirstSiteId(), true, syndicated), "An error occurred in connecting to the 
database . * , syndicated) ; 

if(rs.size() > 0) { 

Enumeration e = rs .elements () ; 
while (e.hasMoreElementsO ) { 

BlurbSiteDB record = (BlurbSiteDB) e.nextElement { ) ; 

blurb_site__name = record. blurb_site_name; 

description = record. description; 

url = record. url; 

} 

} return AdminMenuHTML. getAdminMenu (getFirstSiteld ( ) , this.serverRoot + this . thisServlet, 
getSiteSelectList(getFirstSiteId(), true, syndicated), "The site record selected no longer exists 
in the database. " , syndicated) ; 

} 

return AdminMenuHTML. si teAddOrModify (this.serverRoot + 
this. thisServlet, id, blurb_site_name, description, url, "■) ; 

> 

private String changeSiteSelect (boolean syndicated) { 

String param = getSiteSelectList { -1, false, syndicated); 
if (param. equals ( "error" ) ) { 

return AdminMenuHTML. getAdminMenu (getFirstSiteld () , this.serverRoot + this . thisServlet, 
getSiteSelectList (getFirstSiteld* ) , true, syndicated), "An error occurred in connecting to the 
database . " , syndicated) ; 

} else if (param. equals ( "none" ) ) { 

return AdminMenuHTML. ge t AdminMenu (getFirs t Sit eld( ) , this.serverRoot + this . thisServlet, 
getSiteSelectList {getFirstSiteld {), true, syndicated), "No sites are currently configured. Please 
configure a new site. syndicated) ; 
} else { 

return AdminMenuHTML. selectSite (this.serverRoot + this. thisServlet, "dig" , param) ; 

} 

} 

private String genSiteCodeSelect (boolean syndicated) { 
String param = getSiteSelectList (-1, false, syndicated); 
if {param. equals {" error" ) ) { 

return AdminMenuHTML. getAdminMenu (get First Si teld( ) , this.serverRoot + this . thisServlet, 
getSiteSelectList{getFirstSiteId{),true, syndicated), "An error occurred in connecting to the 
database. " , syndicated) ; 

} else if (param. equals {"none") ) { 

return AdminMenuHTML. getAdminMenu (getFirstSiteld ( ) , this.serverRoot + this. thisServlet, 
getSiteSelectList (getFirstSiteld (), true, syndicated), "No sites are currently configured. Please 
configure a new site . * , syndicated) ; 
) else { 

return AdminMenuHTML. selectSite (this . serverRoot + this . thisServlet, "gensitecode" , param) ; 

} 

} 

/* 

private String changeGroupSelect (boolean syndicated) { 

String param = getSiteSelectList (-1, false, syndicated); 
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if (param. equals {" error ") ) { 

return AdminMenuHTML . getAdminMenu (getFirstSiteld { ) , this . server Root + this . thisServlet , 
getSiteSelectList (getFirstSiteldO x true, syndicated} , "An error occurred in connecting to the 
database . " , syndicated) ; 

} else if (param. equals ( "none ") ) { 

return AdndnMenuHTML. getAdminMenu {getFirstSiteld ( ) , this .serverRoot + this. thisServlet, 
getSiteSelectList {getFirstSiteld () , true, syndicated) , "No sites are currently configured. Please 
configure a new site. * , syndicated) ,- 
} else { 

return AdminMenuHTML. selectSite( this. serverRoot + this . thisServlet , "chg" , param) ; 

} 

) 

*/ 

private String deleteSiteSelect {boolean syndicated) { 

String param - getSiteSelectList (-1 , false, syndicated) ; 
if (param, equals { "error" ) ) < 

return AdminMenuHTML . getAdminMenu (getFirstSiteld ( ) , this . serverRoot + this . thisServlet , 
getSiteSelectList (getFirstSiteld { ) , true, syndicated) , "An error occurred in connecting to the 
database. n , syndicated) ; 

} else if {param. equals ( "none" ) ) { 

return AdminMenuHTML. getAdminMenu (getFirstSiteld () , this . serverRoot + this. thisServlet, 
getSiteSelectList (getFirstSi teld( ), true, syndicated) , "No sites are currently configured. Please 
configure a new site. ", syndicated) ; 
) else { 

return AdminMenuHTML. selectSite{ this. serverRoot + this . thisServlet, " del param) ; 

} 

) 

private String addBlurb(int jbsid, String forwardLink, String forwardPost, boolean syndicated) 

{ 

String param = getGroupSelectList ( jbsid, -1) ; 
if {param. equals ( "error") ) { 
return 

AdminMenuHTML . getAdminMenu { jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database. n , syndicated) ; 
} else if (param. equals { "none" ) ) { 
return 

AdminMenuHTML . getAdminMenu { jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "No blurb 
groups exist for the current site. <BR>Please add a new blurb group before adding a 
blurb. " , syndicated) ; 
) else { 
return 

AdminMenuHTML .blurbAddOrModify (jbsid, -1,-1, forwardLink, forwardPost , getSiteNameFromld ( jbsid) , " " , pa 
ram, " " ) ; 
} 

} 

private String copyBlurb (int jbsid, int jbgid, int jbbid, String forwardLink, String 
forwardPost, boolean syndicated) { 

String param = getGroupSelectList ( jbsid, jbgid); 
String html = getBlurbHTMLFromld (jbbid) ; 
if (par am. equals {"error" ) ) { 
return 

AdminMenuHTML . getAdminMenu ( jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database . * f syndicated) ,* 
} else if (param. equals ("none")) { 
return 

AdminMenuHTML. getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "No blurb 
groups exist for the current site. <ER>Please add a new blurb group before adding a 
blurb . " , syndicated ) ; 
} else { 
return 

AdminMenuHTML. blurbAddOrModifyf jbsid, jbgid, -1, forwardLink, forwardPost , get Si teNameFromld (jbsid) ,ht 
ml, param, " " ) ; 
} 

) 

private String changeBlurb { int jbsid, int jbgid, int jbbid, String forwardLink, String 
forwardPost, boolean syndicated) { 

String param = getGroupSelectList (jbsid, jbgid); 
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String html = getBlurbHTMLFromld { jbbid) ; 
if (param. equals ( "error") ) { 
return 

AdminMenuHTML. getAdminMenu ( jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database . " , syndicated) ; 
} else if (param. equals { "none" ) ) { 
return 

AdminMenuHTML . getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "No blurb 
groups exist for the current site. <BR> Please add a new blurb group before adding a 
blurb. " , syndicated) ; 
} else { 
return 

AdminMenuHTML. blurbAddOrModifyf jbsid, jbgid, jbbid, forwardLink, forwardPost, getSiteNameFromldf jbsid) 
, html , param, " n ) ; 
> 

} 

private String deleteGroupSelect (int jbsid, String forwardLink, String forwardPost, boolean 
syndicated) { 

String param = getGroupSelectList (jbsid r -1); 
if (param. equals ( "error") ) { 
return 

AdminMenuHTML . getAdminMenu { jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database . B , syndicated) ; 
} else if (paraiti. equals ("none") ) { 
return 

AdminMenuHTML. getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "No groups 
are currently configured. Please add a new group. n , syndicated) ; 
} else { 
return 

AdminMenuHTML. select Group {jbsid, forwardLink, forwardPost , "delbg" r param, getSiteNameFromId( jbsid) ) ; 
} 

} 

private String viewBlurbSelect (int jbsid, String forwardLink, String forwardPost, boolean 
syndicated) { 

String param = getGroupSelectList (jbsid, -1); 
if (param. equals ( "error") ) { 
return 

AdminMenuHTML. getAdminMenu {jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database .", syndicated) ; 
> else if (param. equals { "none " ) ) { 
return 

AdminMenuHTML. getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "Ho 
groups are currently configured. Please add a new group. syndicated) ; 
} else { 
return 

AdminMenuHTML. s el ectGroup (jbsid , forwardLink, forwardPost, "viewbb" , param , getSitelSTameFromldf jbsid) ) ; 
} 

} 


private String viewGroupBlurbs (int jbsid, int jbgid, int jbbid, String forwardLink, String 
forwardPost, String message, boolean syndicated} { 
boolean errFlag = false; 
BlurbDB bb = new BlurbDBO; 
Vector v - null; 

Connection conn = dataConnMan.getConnect ion (server, dbname) ; 
String q = "?* ; 

if (forwardLink. indexOf ( ** ? tt ) > -1) 

q = 
try { 

if (jbbid > 0) 

v = bb.getAll (conn, "blurb_site_id = * + jbsid + " and blurb_group_id = " + jbgid + " 
and blurb_id = " + jbbid + " order by created_on desc"); 
else 

v = bb.getAll (conn, "blurb_site„id = " + jbsid + " and blurb_group_id = * + jbgid -i- " 
order by created_on desc") ; 
} catch (Exception ex) { 

BlurtCommon . handleExcept i on { ex > ; 
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errFlag = true; 

} 

dataConnMan . f reeConnection (server , dbname , conn) ; 

Enumeration e = v. elements () ; 
StringBuffer sb = new StringBuf f er { ) ; 

if(v.size() > 0) { 

conn = dataConnMan. getConnecti on (server, dbname); 
while (e.hasMoreElementsO ) { 

BlurbDB record - (BlurbDB) e . nextElement ( } ; 
if (jbbid > 0) { 

sb. append ( "<trxtd valign=top align=center>N/A</td>" ) ; 
} else { 

sb.appendC<trxtd valign=top align=center> [<A HREF=\ W " + forwardLink + q + 
" jbact=copybb&jbsid= n + jbsid + "ijbgid^ + jbgid + "&jbbid= n + record.blurb_id + 
"\"><B>Copy</B></A>]<BR>") ; 

sb. append ( H [<A HREF= \ " w + forwardLink + g + * jbact=chgbb& jbsid- " + jbsid + "fcjbgid^ w + 
jbgid + "&jbbid=" + record. blurb_id + " \ n xB>Modify</Bx/A>}<BR>" ) ; 

sb. append (" [<A HREF=\ nn + forwardLink + q + " jbact=delbb&jbsid= M + jbsid + "&jbgid=" + 
jbgid + "&jbbid=" + record. blurb_id + n \ "><B>Delete</Bx/A>J</ td> " ) ; 
} 

sb. append ( "<td valign=top align=left> n + HTMLQuoter . toQuoted ( record . html ) + "</tdxtd 
valign=top align=lef t> ■ + record.html + "</tdx/tr> n + '\r'); 
} 

dataConnMan . f reeConnection ( server , dbname, conn) ; 
} else { 
return 

AdminMenuHTML.getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "The 
group <B>" + getGroupNameFromld ( jbgid) + "</B> doesn't contain any HTML blurbs syndicated) ; 
} 

if (errFlag) 
return 

AdminMenuHTML-getAdminMenu{ jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database .", syndicated) ; 
else 

if (jbbid > 0) 
return 

AdminMenuHTML.deleteBlurb( jbsid, jbgid, jbbid, forwardLink, f orwardPost , sb. toString { ) ,getSiteNameFrom 
Id (jbsid) , getGroupNameFromld (jbgid) , message) ; 
else 
return 

AdminMenuHTML.viewGroupBlurbs (jbsid, jbgid, forwardLink, f orwardPost , sb. toString ( ) , getSiteNameFromld 
(jbsid) , getGroupNameFromld (jbgid) , message) ; 
> 

private String genera teBlurbCode (int jbsid, String forwardLink, String forwardPost, boolean 
syndicated) { 

String param = getGroupSelectList (jbsid, -1); 
if (par am. equals ("error") ) { 
return 

AdminMenuHTML.getAdminMenu( jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database. *, syndicated) ; 
} else if (param. equals ( "none *) ) { 
return 

AdminMenuHTML.getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "No groups 
are currently configured. Please add a new group. n , syndicated) ; 
} else { 

return AdminMenuirmL.selectGroup( jbsid, forwardLink, forwardPost, "genbcode" , param, 
getSiteNameFromld (jbsid) ) ; 
} 

} 

private String deleteSiteDetails (HttpServletRequest request, HttpServletResponse response, 
boolean syndicated) { 

boolean errFlag = false, - 

int id = Integer .parselnt (request .get Parameter ( "jbsid" ) . trim ( ) ) ; 
String blurb_site_name - 
String description = " " ; 
String url = " ■ ; 
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Vector rs = null; 

BlurbSiteDB bs = new BlurbSiteDB () ; 

Connection conn = da taConnMan.getConnect ion (server , dbname) ; 
try { 

rs = bs .getAll (conn, w blurb_site_id = " + id) ; 
} catch (Exception e) { 

BlurbCommon.handleException(e) ; 
err Flag = true; 

> 

dataConnMan . freeConnect ion (server, dbname, conn) ; 
i f ( errFlag ) 

return AdminMenuHTML . getAdminMenu (getFirstSiteld ( ) , this .serverRoot + this.thisServlet, 
getSiteSelectList (getFirstSiteldO , true, syndicated) , "An error occurred in connecting to the 
database . * , syndicated) ; 

if(rs.size{) > 0) { 

Enumeration e = rs . elements O ; 
while (e.hasMoreElements () ) { 

BlurbSiteDB record = (BlurbSiteDB) e . nextElement () ; 

blurb_site_jiame = record. blurb_s it e_name; 

description = record. description; 

url = record.url; 

} 

} else { 

return AdminMenuHTML. getAdminMenu (getFirstSiteld () , this . serverRoot + this.thisServlet, 
getSiteSelectList (getFirstSiteld ( ), true, syndicated) , "The site record selected no longer exists 
in the database . n , syndicated) ; 
} 

return AdminMenuHTML . siteDelete ( this . serverRoot + 
this.thisServlet, id, blurb_site_name, description, url , ) ; 
} 

private String deleteGroupDetails (int jbsid, String forwardLink, String forwardPost, 
HttpServletRequest request, HttpServletResponse response, boolean syndicated) { 
boolean errFlag = false; 

int id = Integer. parselnt (request. getParameter ( " jbgid") .trim() ) ; 
String bl urb_.gr oup_name = " " ; 
Vector rs = null; 

BlurbGroupDB bg = new BlurbGroupDB ( ) ; 

Connection conn = dataConnMan. get Connect ion (server, dbname) ; 
try { 

rs = bg. getAll (conn, n blurb_group_id = " + id); 
} catch (Exception e) { 

BlurbCommon.handleException (e) ; 
errFlag = true; 

} 

dataConnMan. freeConnec t ion (server, dbname, conn); 
if (errFlag) 
return 

AdminMenuHTML. getAdminMenu ( jbsid, forwardLinlc, getSiteSelectList (jbsid, true, syndicated) , "An error 
occurred in connecting to the database . * , syndicated) ; 

if(rs.size() > 0} { 

Enumeration e = rs - elements () ; 
while {e.hasMoreElements {) ) { 

BlurbGroupDB record = (BlurbGroupDB) e . nextElement () ; 

blurb_group_name = record.blurb_group_name; 

} 

} else { 
return 

AdminMenuHTML. getAdminMenu (jbsid, forwardLink, getSiteSelectList (jbsid, true, syndicated) , "The group 
record selected no longer exists in the database. tt , syndicated) ; 
} 

return 

AdminMenuHTML. groupDelete( jbsid, id, forwardLink, f orwardPost,blurb„group__name, * n ,getSiteNameFromId( 
jbsid) ) ; 
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} 


private void validateSiteO { 
} 
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//a test comment 


package com. activedatax. products .Blurb; 

import javax.servlet.*; 

import javax.servlet .http.*; 

import java.io.*; 

import java.util. * ; 

import java.sql.*; 

impor t j ava .net.*; 

import gnu . regexp . * ; 

import com. activedatax. sql .HttpServletDb; 

import com. activedatax .products . Blurb. dbmodules . BlurbDB? 


J -* * 

This is a rewrite of the PublishNow 2.x jSyndicate servlet for use with Active Data Publisher 
3.0 and Community Exchange (Af f iliateNow) 

©author John E. Wetzel 

©version 1.0 

@date 15-MAY-2000 
*/ 

public class JBlurb extends HttpServletDb implements SingleThreadModel { 
private BlurbCommon mycommon ; 
private String server = " " ; 
private String dbname = an ; 
private String thisServlet = 
private String serverRoot = " " ; 

public void init {ServletConf ig config) throws ServletException { 
super . in it (conf ig) ; 

//USE BlurbCommon. class TO GET PROPERTIES -- SERVER & DATABASE NAME 

mycommon = new BlurbCommon { ) ; 

Properties p = mycommon . get Props {} ; 

serverRoot = p.getProperty ( "server. root" } ; 

server = p.getProperty ( "default . server w } ; 

dbname = p.getProperty { "default .dbname" ) ; 

//store the alias in 

p = mycommon. get AliasesO ; 

thisServlet = p.getProperty ( "JBlurb" ) ; 

} 

//Process the HTTP Get request 

public void doGet (HttpServletRequest request, HttpServletResponse response) throws 
ServletException, IOException { 
String output HTML = tt " 
String param - M " ; 

String action = request .get Parameter { "jbact" ) ; 
outputHTML - 

convertTojs (getRandomBlurb( Integer .parse In t {request . getParameter ( n jbs id" ) .trim() ) , 
Integer .parselnt { request. get Parameter { " jbgid") .trim( ) } ) ) ; 

response . setContentType ( "text /html " ) ; 
PrintWriter out = response.getWriter ( ) ; 
out . print In (outputHTML) ; 
return; 

} 

public String getRandomBlurb (int blurb_site_id, int blurb_group_id) { 
boolean errFlag = false ; 
int count = 0; 
int tempid, blurb_id; 
double tempval; 

String blurbHTML = "" r tempStr = " " ; 
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BlurbDB bb - new BlurbDB ( ) ; 
Vector rs = null; 

Hashtable idHash - new HashtableO; 

Connection conn = da taConnMan.getConnect ion (server, dbname) ; 

String sql = "select blurb . blurb_id id from blurb_site, blurb_group, blurb * 

+ • where upper (blurb_site. status} = 'Y f and upper (blurb_group. status) = ' Y' and 

upper (blurb. status) = 'Y' n 

+ * and blurb. blurb_site_id = blurb_group .blurb_site_id and blurb. blurb_site_id 

blurb_site .blurb_site_id ff 

+ " and blurb. blurb_group_id = blurb_group.blurb_group_id* 

+ B and blurb. blurb_site_id - ? and blurb. blurb_group_id = ✓ 
try { 

PreparedStatement stmt = conn.prepareStatement (sql) ; 

stmt .clear Parameters ( ) ; 

stmt .set Int (1, blurb_site_id) ; 

stmt . set Int ( 2 , blurb_group_id) ; 

ResultSet rr = stmt . executeQuery () ; 

while (rr.nextt)) { 
count++ ; 

idHash. put (String. valueOf (count) , rr .getString ( "id" ) ) ; 

> 

rr .close { ) ; 
stmt .close { ) ; 

> catch (Exception e) { 

BlurbCommon.handleException (e) ; 
errFlag = true; 

} 

dataConnMan . f reeConnection ( server, dbname, conn) ,- 

if (count > 0) { 

tempval = Math . floor (count * Math . random {)) ; 

tempid = (int) tempval + 1; 
// System. out .println (tempid) ; 

tempStr = idHash. get (String. valueOf (tempid) ). toString () ; 

blurb_id = Integer .parselnt {tempStr) ; 
// System. out .println (blurb_id) ; 

conn = dataConnMan. getConnection (server, dbname) ; 
try { 

rs = bb. get All (conn, "blurb__id = n + blurb_id) ; 
} catch (Exception e) { 

BlurbCommon.handleException (e) ; 
errFlag = true; 

} 

da t aConnMan , f r eeConne c t i on { s erver , dbname , conn) ; 

Enumeration e = rs. elements () ; 
while (e.hasMoreElements { ) } { 

BlurbDB record = (BlurbDB) e . next Element () ; 

blurbHTML = record . getHtml ( } ; 

} 

) 

if (errFlag) 

return *<! database error > tt ; 

else 

return blurbHTML; 


public String convertTojs (String HTMLtext) { 

try { 

HTMLtext ~ new 
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RE ( " \ " com . acti vedatax . pr oduc ts . Af f i 1 i a te . Da tamodul es - Retr i evelmage " ) . subs t i tuteAl 1 { HTMLtext , 
• \»» + serverRoot + "com. activedatax. products . Affiliate. Datamodules . Re tri evelmage" ) ; 

HTMLtext = new RE ( " [Ss } [Rr] [Cc] *= 
*\ "com. activedatax -products. Affiliate. Datamodules. Retrievelmage* ) . substituteAll (HTMLtext, w src=\ 
+ serverRoot + " com. activeda tax. product s . Affiliate. Datamodules .Retr i evelmage n ) ; 

HTMLtext = new RE( tt [Ss] [Rr] [Cc] *= 
*\ n com.rnci. products. DataModules .Retr ievelmage" ). subs ti tuteAl 1 {HTMLtext , K src=\" B + serverRoot + 
"cora.rnci .products - Da taModules .Retrievelmage" ) ; 

HTMLtext = new 

RE( " \ 9 com. rnci. products. Da taModules. Re trieveAttachment") . subs ti tut ©All (HTMLtext, " \ n n + 
serverRoot + "com.mci .products .DataModules .Re trieveAttachment * ) ; 
} 

catch (Except ion e) { 

BlurbCommon.handleException(e) ; 

} 


String scriptHTML = n " ; 
int startSearchAt - 0; 

int scriptLoc = indexOf I gnoreCase (HTMLtext, n < SCRIPT" , startSearchAt) ; 
if (scriptLoc > -1) { //Check for client scripts and separate them from regular HTML 
try { 

int endScriptLoc; 

int articleLength = HTMLtext . length ( ) ; 

StringBuffer sbArticle = new StringBuf f er { articleLength + 1); 
StringBuffer sbScripts = new StringBuf fer () ; 
while (scriptLoc > -1) { 

endScriptLoc = indexOf IgnoreCase (HTMLtext , "</SCRIPT> B , scriptLoc) ; 

sbArticle. append (HTMLtext. substring (startSearchAt scriptLoc) ) ; 

sbScripts. append (HTMLtext. subs tringt (indexOf IgnoreCase (HTMLtext, n > n , scriptLoc) +1) , endScriptLoc) 
sbScripts - append ( ' \n ' ) ; 
sbScripts . append ( ' \r ' ) ; 

// System. out. print In ("The HTML: w + HTMLtext .substring (startSearchAt, scriptLoc) ) ; 
//System. out . print In { "The Script: n + 
HTMLtext. subs tringt (indexOf IgnoreCase (HTMLtext, ">", scriptLoc )+l) , endScriptLoc) ) ; 

startSearchAt = endScriptLoc + 9; 

scriptLoc = indexOf IgnoreCase (HTMLtext, "<SCRIFT" r startSearchAt ) ; 

} 

sbArticle. append (HTMLtext. substring (startSearchAt, articleLength - 1) ) ; 
/ /System. out .print In (sbArticle. toString( ) ) ; 
//System. out. print In (sbScripts .toStringt) ) ; 

scriptHTML = sbScripts . toString () ; //contains just the scripts 7 code 
HTMLtext = sbArticle. toString ( ) ; //contains just the article HTML 

} 

catch (Exception e) { 

BlurbCommon . handl eExcept ion ( e ) ; 

} 

} 

HTMLtext = HTMLtext. replace (' \r' , ' '); 
"HTMLtext = HTMLtext. replace (' \n' , ' r ); 
try { 

HTMLtext = swapStrings (HTMLtext, n \\ w , "WW") ; 
HTMLtext = swapStrings (HTMLtext, "\ \\\ '") ? 
HTMLtext = swapStrings (HTMLtext, "\ n n \\\ nn ) ; 

} 

catch (Exception e) { 

BlurbCommon . handl eExcept ion ( e) ; 

} 

return scriptHTML + " document .write + HTMLtext + "'); "? 

} 

public static String swapStrings (String Textln, String OldString, String NewString) { 
int OldStringStartAt; 

int OldStringLength = OldString. length () ; 
int NewStringLength = NewS t ring. length () ; 
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String TempText = Textln; 

OldStringStartAt = indexOf IgnoreCase {TempText , OldString, 0) ; 
while (OldStringStartAt != -1) { 

TempText = TempText . substring ( 0, OldStringStartAt) + NewString + 
TempText. substring (OldStringStartAt + OldStringLength) ; 

OldStringStartAt = indexOf IgnoreCase (TempText, OldString, OldStringStartAt + 
NewStringLength) ; 
} 

return TempText; 

} 

public static int indexOf IgnoreCase (String TempText, String substring, int StartAt) 
return TempText . toLowerCase ( } . indexOf ( substring . toLowerCase ( ) , StartAt ) r 

> 
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//A simple comment 


package com. act iveda tax. products .Blurb ; 

import j avax . servlet . * ; 
import javax. servlet .http. * ; 
import java.io.*; 
import java.util.*; 
import java.sql.*; 

import com . act iveda tax . product s . Blurb - * ; 

import com. act iveda tax. products - Blurb, dhmodules. * ? 

import gnu . regexp . * ; 

import com . act iveda tax . net . url . Ut il ; 
import j ava . net . Mai f ormedURLException ; 
import com . act iveda tax . util s . HTMLQuoter ; 

public class JBlurbAdmin extends AdminMenu { 
private BlurbCommon my common; 
private String server = Bn ; 
private String dbname = B * ; 
private String thisServlet = " " ; 
private String serverRoot = " " ; 
private String fPost = 

private static int itemsToKeep = 400, minutesToLive = 10; //will be set by init<) later 

private static long lastModif ied; 

private static Vector contents - new vector O ; 

private Sentinel sentinel - null ; 

public void init (ServletConf ig config) throws ServletException { 
super . in it (config) ; 

System.out.println{ "Init Method executed") ; 
sentinel = new Sentinel {items ToKeep, minutesToLive) ; 
//USE BlurbCommon . class TO GET PROPERTIES 
my common - new BlurbCommon { ) ; 
Properties p = mycommon. get Props () ,- 
serverRoot = p . getProperty ( " server . root " ) ; 
server = p. getProperty ( "default . server ") ; 
dbname = p . getProperty ( " def aul t . dbname " ) ; 

try { 

this .itemsToKeep = In teger .parselnt (p. getProperty { "cache,! terns" } ) ; 
} catch {NumberFormatException e) { 
System. err .println (e. getMessage ( ) ) ; 
e.printStackTraceO ; 
th i s . i terns ToKeep = 400; 

> 

try { 

this .minutesToLive = Integer .parselnt {p. getProperty ( "cache .minutes " ) ) ; 
} catch (NumberFormatException e) { 
System. err. println(e.getMessage( ) ) ; 
e.printStackTraceO ; 
this .minutesToLive - 10; 

} 


//store the alias in 

p - mycommon .get Alias es () ; 

thisServlet ~ p. ge t Property ("JBlurbAdmin ") ; 
fPost = serverRoot + thisServlet ; 

> 

/**Process the HTTP Get request*/ 

public void doGet (HttpServletRequest request, HttpServletResponse response} throws 
ServletException, IOException { 

String outputHTML = " n , documentURL = tt " , documentHost = " " , jbact =■ " n , jpostbact = 
jbts = " n ; 
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String contld ; 
boolean errFlag = false; 
int jbsid = -1? 
Content cont; 

response. setContentType ( n text /html* ) ; 
PrintWriter out = response .getWr iter () ; 

HttpSession session = request .getSession (false); 

if (session ~= null) session = request .getSession ( true) ; 

documentURL = removeAllParams (request.getParameter ( 11 jbdurl" ) . trim() ) ; 
//get the blurb site id from the request parameters 
try { 

jbsid = Integer. parselnt (request. getParameter ("jbsid") .trimD ) ; 
} catch (Exception e) { errFlag = true; } 

if (i errFlag) errFlag - validateHost (jbsid, parseHostFromURL {documentURL) ) ; 

if (errFlag) . . ^ ^ 

output HTML = "document-write <'<B>This web site is not authorized to view the content 

requested. <\ \ /&>' ) ; 
else { 

jbact = request.getParameter{ "jbact* ) ; 
if (jbact != null) { 

if (jbact. equal slgnoreCase ( "getpostdata ") ) { 

jbts = request. get Parameter ( "jbts") .trim() ; 

jpostbact = request .get Parameter (" jpostbact") -trim() ; 

contld = session. getldO + + jbsid + n ," + documentURL + + jpostbact + " , * + 

jbts; 

// System, out .print In (contld) ; 
cont - lookup (contld) ; 
if (cont != null) 

outputHTML = cont. detail; 
else 

outputHTML = convertTojs(doBlurb (request, response, documentURL, this. f Post, true)) 
out .print In (outputHTML) ; 
return; 

} 

outputHTML = convertTojs(doBlurb(request, response, documentURL , this. f Post, true)); 

} 

out .print In (outputHTML) ; 
return; 

> 

/**Process the HTTP Post request*/ 

public void doPost(HttpServletRequest request, HttpServletResponse response) throws 
ServletException, lOException { 

String outputHTML = n referringURL = •", redirectURL = jpostbact = "•, q 

String contld ; 
boolean errFlag = false ; 
int jbsid = -1; 
Content cont; 

HttpSession session = request .getSession (false); 

if (session = null) session = request .getSession (true) ; 

//get the referring URL from the request header and use as the forward link 
referringURL = removeAllParams (request .getHeader ( "REFERER" )) ; 
if (referringURL. equals ("error" ) ) errFlag = true; 


//get the blurb site id and the form post action from the request parameters 
try { 

jbsid = Integer.parseInt(request.getParameter ( M jbsid") -trim{) ) ; 
jpostbact = request. get Parameter ("jbact" .trim() ) ; 
} catch (Exception e) { errFlag = true; } 

if (errFlag == false) errFlag = validateHost (jbsid, parseHostFromURL (referringURL) ) ; 
iff! errFlag) { 

//process the posted form and convert to JB for output 
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outputHTML = convertTojs(doBlurb(request, response, ref erringURL, this. f Post, true) ) ; 

//store the resulting JS in a Vector for later retrieval via browser JavaScript HTTP GET 
if {ref erringURL. indexOf ( w ?" ) > -1) 
q = "&"; 

lastModified = System. currentTimeMill is {) ; 

redirectURL = referringURL + q + n jbsid=" + jbsid + "&jbact=getpostdata&jpostbact=" + 
jpostbact + "&jkts=" + lastModified; 

contld = session. getldO + * , n + jbsid + + ref erringURL + + jpostbact + ■,- + 

lastModif ied; 

/ /System. out. print In (contld) ; 

cont = new Content {contld, outputHTML, lastModified); 
contents . addElement (cont) ; 

} else { //there has been an error or the referring URL is not allowed 
redirectURL = ref erringURL ; 

} 

//redirect the browser to the referring page with the appropriate parameters needed to 
retrieve the JS from the Vector 

response. sendRedirect (redirectURL) ; 
return ; 

} 

/**Clean up resources*/ 
public void destroy (} { 

System. out. pr in t In { "Destroy method running" ); 

sentinel .quit = true; 

contents = null; 

} 

public String convertTojs (String HTMLtext) { 
try { 

HTMLtext = new , , -, ,™,r *. ^ 

RE{"\ n com. activedatax. products. Af filiate. Datamodules.Retrievelmage") . subs ti tut eAll (HTMLtext, 

■\»» + serverRoot + " com. activeda tax. products .Affiliate. Datamodules .Retrievelmage" ) ; 

HTMLtext = new RE P [Ss] [Rr] [Cc] * = ^ - „ \*. 

*\ "com. activeda tax. products. Affiliate. Datamodules. Retrievelmage^ .subs ti tut eAll (HTMLtext , src-\ 
+ serverRoot + "com. activeda tax. products .Affiliate. Datamodules .Retrievelmage" ) ; 

HTMLtext = new RE{" [Ss] [Rr][Cc] *= 
*\"com.rnci. products. DataModules. Retrievelmage"). subs tituteAll (HTMLtext, "src=V H + serverRoot + 
"com.mci. products .DataModules .Retrievelmage" ) ; 

HTMLtext = new t ,. Ht x 

RE("\ n com. mci. products. DataModules. RetrieveAttachment" ) . substituteAll {HTMLtext, \ + 
serverRoot + "com.mci .products .DataModules .RetrieveAttachment ") ; 
) 

catch (Exception e) { 

System. err. println{e.getMessage() ) ; 
e.printStackTraceO ; 

} 

String scriptHTML = 
int startSearchAt - 0; 

int scriptLoc = indexOf IgnoreCase {HTMLtext, "<SCRIPT" , startSearchAt) ; 

if (scriptLoc > -1) { //Check for client scripts and separate them from regular HTML 
try { 

int endScriptLoc ; 

int articleLength = HTMLtext . length () ; 

StringBuffer sbArticle = new StringBuffer (articleLength + 1); 
StringBuffer sbScripts = new StringBuffer*); 
while {scriptLoc > -1) { 

endScriptLoc = indexOf IgnoreCase (HTMLtext , "</SCRIPT>" , scriptLoc) ; 

sbArticle. append (HTML text. substring (startSearchAt, scriptLoc) ) ; 

sbScr ipts. append (HTMLtext. substring ( {indexOf IgnoreCase {HTMLtext , ">", scriptLoc) +1) , endScriptLoc) ) 
sbScripts . append ( ' \n ' ) ; 

sbScripts . append ( ' \r ' ) ; , 
/ /System. out .print In { "The HTML: » + HTMLtext .substring (startSearchAt, scriptLoc) ) ; 
//System.out.println("The Script: " + 
HTMLtext. substring ( (indexOf IgnoreCase {HTMLtext, *>" , scriptLoc) +1) , endScriptLoc) ) ; 
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startSearchAt = endScriptLoc + 9; 

scriptLoc = indexOf IgnoreCase (HTMLtext, "< SCRIPT n , StartSearchAt) ; 

sbArticle. append (HTMLtext. substring (startSearchAt, art icleLength - 1) ) ; 
// Sy s tem. ou t. print In (sbAr tide. toString {) } ; 
// Sy s t em. ou t. pr int In (sbScripts. toString 0 ) ; 

scriptHTML - sbScripts . toString { ) ; //contains just the scripts' code 
HTML text = sbArticle. toString (> ; //contains just the article HTML 

} 

catch (Exception e) { 

Sys t em. err. print In ( e.getMes sage () ) ; 
e . pr intStaclcTrace ( } ; 

} 

} 

HTMLtext = HTML text . replace ( ' \r ' , ' ' ) ; 
HTMLtext - HTMLtext. replace (' \n' , ' '); 
try { 

HTMLtext = swaps trings (HTMLtext, "\\ n , n \\\\") ; 
HTMLtext - swapStrings(HTMLtext / ,, \' n , , '\\\ ,n ) ; 
HTMLtext = swapS trings( HTML t ext, "\ nn , "\\V") ; 

} 

catch (Exception e) { 

System. err. print In (e.getMessage( ) ) ; 
e .prints tackTrace { ) ; 

} 

return scrip tHTML + " document .write + HTMLtext + " } ; *; 


public static String swapStrings {String Textln, String OldString, String NewString) { 
int OldStringStartAt; 

int OldStringLength = OldString. length ( ) ; 
int NewStringLength = NewString . length () ; 
String TempText = Textln; 

OldStringStartAt = indexOf I gnoreCase (TempText , OldString, 0); 
while (OldStringStartAt \- -1) { 

TempText = TempText . substring ( 0, OldStringStartAt) + NewString + 
TempText. substring (OldStringStartAt + OldStringLength); 

OldStringStartAt = indexOf IgnoreCase{ TempText, OldString, OldStringStartAt + 
NewStringLength) 
} 

return TempText; 

} 

public static int indexOf IgnoreCase( String TempText, String substring, int StartAt) { 
return TempText . toLowerCase ( ) . indexOf ( substring . toLowerCase ( ) , StartAt) ; 

} 

private String removeAllParams (String URL) { 
String tempURL = URL; 
Util myUtil = new UtilO; 
try { 

myUtil.setOriginalURL(URL) ; 
myUtil . setParamToRemove ( " jbdurl " ) ; 
tempURL = myUti 1 . getRemovedParairiURL ( } ; 
myUtil . setOriginalURL ( tempURL) ; 
myUtil . setParamToRemove ( " jbrand* ) ; 
tempURL = myUtil . getRemovedParamURL () ; 
myUtil . setOriginalURL (tempURL) ; 
myUtil . setParamToRemove ( ■ jbact ■ ) ; 
tempURL - myUtil.getRemovedParamURLO ; 
myUtil . setOriginalURL ( tempURL) 
myUtil . setParamToRemove ( " jbsid" ) ; 
tempURL = myUtil.getRemovedParamURLO; 
myUtil . setOriginalURL ( tempURL) ; 
myUtil . setParamToRemove ( " jbgid" ) ; 
tempURL - myUtil.getRemovedParamURLO; 
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myUtil . setOriginaltfRL (tempXJRL) ; 
myUtil . setParamToRemove { ■ jbbid" ) ; 
tempXJRL = myUtil.getRemovedParamXJRLO ; 
myUtil . setOriginalXJRL (tempXJRL) ; 
myUtil . setParamToRemove ( M jpostbact" ) ; 
tempURL - myUtil . getRemovedParamXJRL { ) ; 
myUtil . setOriginalXJRL (tempXJRL) ; 
myUtil . setParamToRemove ( " jbts" ) ; 
tempURL = myUtil .getRemovedParamXJRL ( ) ; 

} catch (MalformedURLException mue) { 
mue.printStackTraceO ; 

//put in garbage XJRL that will never match JW 12/4/00 
tempXJRL = "error"; 

} 

//System, out. print In (tempURL) ; 
return tempXJRL ; 

} 

private String parseHostFromXJRL (String targetXJRL) { 

StringTokenizer tokenizer = new StringTokenizer (targetURL, "/")? 
int tokencount - tokenizer .countTokens () ; 
int i; 

String returnHost = ttR ; 
if (tokencount > 1) { 

for (i = 1; i < 3; i++) returnHost = tokenizer .next Token () ; 
} else { 

returnHost - " " ; 

} 

return returnHost ; 

} 

private boolean validateHost (int jbsid, String targetHost) { 
//false: XJRL - Site match found 
//true: bad URL 
boolean errFlag = false; 
BlurbSiteDB bs = new BlurbSiteDB () ; 
Vector v = null; 

Connection conn = da taConnMan.getConnect ion {server, dbname); 
try { 

v = bs. get All (conn, n blurb_site_id = K + jbsid + " and upper (url) like + 
targetHost . toUpperCase ( ) + "%'"); 
} catch (Exception e) { 

BlurbCommon.handleException(e) ; 
errFlag = true; 

> 

dataConiiMan.freeConnection{ server, dbname, conn) ; 
if (v. size () < 1) errFlag - true? 

return errFlag ; 

} 

Content lookup (String contentID) { 
Content cont; 
int index = -1; 

for (int i=0; i<contents . size ( ) ; { 
cont - (Content) contents . elementAt { i ) ; 

if (content ID. equals (cont. contentID)) return (Content) contents .elementAt (i) 

} 

return null; 

} 

class Content { 

String contentID, detail; 
long timestamp; 

Content (String contentID, String detail, long timestamp) { 
this. contentID = contentID; 
this. detail - detail; 

this. times tamp = times tamp/ 60000; //converts milliseconds to minutes 
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} 

} 


private class Sentinel extends Thread { 
int i terns ToKeep; 
int minutesToLive; 
boolean quit ~ false; 

Sentinel (int itemsToKeep, int minutesToLive) { 
System. out. print In ("Sentinel Constructor rt ); 
this.itemsToKeep = itemsToKeep; 
this. minutesToLive = minutesToLive ; 
setPriority (Thread. MIN__PRI0R1TY) ; 
start () 


public void run{) { 
int itemsToRemove ; 

while (!quit) { // this keeps cleanup alive until servlet is destroyed 
freshen { ) ; 

if (contents . size ( ) > itemsToKeep) trim ( ) ; 
//System, out .println< contents. size { } ) ; 
/ /System. gc() ; 
try { 

Thread. sleep(5000) 

} 

catch (InterruptedException ex) { 
System.err.println(ex.getMessage() ) ; 
ex.printStackTraceO ; 

//System. out. println ( "Sentinel ran at:" + System.currentTimeMillis { ) ) 

} 

} 

private void trim() { 

int itemsToRemove = contents . size () - itemsToKeep; 
int trimmed = 0; 

for (int i~0; i< itemsToRemove; ++i) { 
contents . removeElementAt ( i ) ; 

//System. out.println{ "Removed: M + contents . el ementAt (i) . toString ()) ; 
Thread. yield () ; 
trimmed++ ; 

} 

if {trimmed > 10) contents . trimToSize () ; 


private void freshen {) { 

long currentTime ~ System. currentTimeMil lis ( ) /60000; 
Content cont; 

for (int i=0; i<contents . size ( ) ; ++i) { 
cont ~ (Content) contents.elementAt(i) ; 
if (cont. time stamp + minutesToLive < currentTime) { 
contents . removeElementAt ( i ) ; 

//System. out.printlnt "Expired: " + cont .contentID) ; 
Thread.yield( ) ; 

) 

> 

) 

> 
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